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-١‏ طريقة تثبيت Visual Basic.Net 2005 Express‏ 


- التعرف على واجهة |5٤‏ 

۳- التعرف على القوائم البرنامج 

> - صندوق الإدوات فى الفيجوال بيسك دوت نت 
-٥‏ أنشاء مشروع جديد فى بيئة الدوت نت 
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المراجع 


Prog : Mohamed Youssef 


Prog : Mohamed Youssef 


مرجباً بك فى هذا الكتاب الذى يشكل مقدمة شاملة ألى برمجة الفيجوال بيسك دوت نت بأستعمال البرنامج 
البرنامج مايكروسوفت فيجوال بيسك ٠٠٠٠١‏ . 
لقد صممت هذا الكتاب التعليمى مع الاخذ فى الاعتبار مجموعة متنوعة من مستويات المهارات و الموضوعات 
المتنوعة . والنتيجة هى أن المبرمجين الجدد يستطيعون ان يتعلموا أساسيات البرامج فى سياق برامج حقيقية 
مفيدة » و يستطيع مبرمجوا الفيجوال بيسك ٠‏ الخبراء أجادة بسرعة أدوات و أذا كنت مبدئ فى عالم البرمجة فتكون 
سعيد الخط لأستخدامك تقنية الدوت نت . 


ما يكمل هذا الاسلوب الشامل هو بنية الكتاب > أجزاء و ملحق منظمة حسب الموضوع » ۰ فصلا › و 
باستعمال هذا الكتاب ». سنتعلم بسرعة كيفية أنشاء برامج الفيجوال بيسك ٠٠‏ ذات نوعية متطورة و برامج 
قواعد البيانات و تطبيقات الويندوز. 


ماهو الفيجوال بيسك؟ 


حینما أصدرت (میكروسوفت) أول نسخة من لغ icوھB‏ اھں‌وءا۷ عام ۱۹۹۱ء لم يكن في حسبانها أنها ستكتسب كل 

هذه الشهرة وستحقق كل هذه الشعبيّة! 

إن لغة 8۸51٥‏ القديمة نُعَذ من أسهل لغات البرمجةء ولكنها لم تستطع الصمود في المنافسة مع لغات البرمجة 

الأخرى بسبب قدراتها المحدودة. 

كان ذلك كذلك» حثى أصدرت (ميكروسوفت) إصدارات ۷B‏ المتتابعةء لتنتقل لغة 8۸51٥‏ من قفار الدوس المجدبة إلى 

مراعي الويندوز الخصبة» مانحة للمبرمج القدرة على إنشاء برامج ذات واجهة مرئيّةء بأسهل طريقة وفي أسرع 

وقت. 

ومنذئذٍ ولغة ۷8 تتصدر قائمة مبيعات لغات البرمجة» لتدخل في بناء التطبيقات التجاريّة وتطبيقات قواعد البيانات 

البسيطةء وبرامج الوسائط المتعددة aالمہآ†اں‏ والكثير من الألعاب۔ 

ولكن للأسف ..دائما وأبدا كانت ۷8 أدنى من باقي لغات البرمجةء فتطبيقائها أبطأ نسبيًا وأكبر حجماء وتعاني من 

بعض أوجه القصور فى الأداء. 

ولقد استمرت TT Tae‏ إصدارات مختلفة» وفي كل إصدار جديدٍ كانت تعالج بعض 

المشاكل القديمة وتضيف المزيد من القدرات» لتضيق الفجوة شيا فشيئا بين ۷8 وباقي لغات البرمجة. 

ثم أخيرا أقدمت (ميكروسوفت) على الخطوة التي طال انتظارها.. أصدرت نسخة جديدة بكل المقاييس من ۷6B‏ » بنتها 

من جذورها طءاهإءء ۴۲٠۳‏ لتجعلها نذا حقيقيًا لب+٥۷‏ » بحيث يمكنك أن تقول بثقة: إن العصر الذهبي ل ۷٥++‏ 

آخد في الأفول بلا رجعة» حبث سینحصر استخدامها في تصميم المحركات Engines‏ التي تدخل في بناء تطبيقات 

أخرى» أو في كتابة الكود الذي يتيح للكمبيوتر التحكم في آلات أخرى» ولكن استخدامها سيتراجع بلا شك في تطبيقات 

E2)‏ والتطبيقات التجارية وتطبيقات قواعد البيانات والوسائط المتعددة ومعظم الألعاب وما شابه» نظرَا لصعوبتها 
تعقيدها وطول الوقت اللازم للبرمجة بها! 

ie),‏ أن هذا هو السبب الذي دفع (ميكروسوفت) لإصدار اللغة الجديدة#C‏ › التي تعتبر توأما ل ۷B‏ إلا إنها تستخدم 

قواعد ++ في كتابة الأوامر» مما یشگل لمبرمجي /٥++‏ إغراء تصعب مقاومته للانتقال إليها. 

ولكن مهما كانت سهولة#C‏ › فان ۷8 يصرعها في هذا المضمار» فهو أقرب ما يكون للغة الإنجليزيّة العاديةء ولا 

يحتوي على الرموز الكثيرة المملة التي تملأ++٥‏ › مثل ; » ++› == ....||إلى آخر هذه الرموز التي تجعل احتمالات 

الخطا عند كتابة الكود أعلى» وتجعل البرنامج أصعب فهمًا وأقل ألفة عند قراءته. 


ما الحديد الفیحوال بيسك دوت نت؟ 


١‏ إن التطويرات التي لحقت ب ۷/8.۸6 من الكثرة بحيث لن نستطيع أن نحيط بها كلها هنا.. ولكن يكفي أن نذكر منها ما 
يلي: 

} لم تعد ل ۷8٥‏ واجهة استخدام مستقلةء فكل لغات 8 تستخدم واجهة واحدة» مليئة بالأدوات التي سهل بطريقة 
مدهشة عمليّة تصميم البرنامج.. إن هذه الميزة تسمح لك بإنشاء تطبيقات تدخل فيها أكثر من لغة برمجةء دون أن 
تحتاج لفتح أكثر من واجهة.. إنها واجهة واحدة فقط لكل المبرمجين. 
هناك إمكانيات جديدة في نافذة محرر الكود» منها قيام اللغة بكتابة جملة نهاية المقطع تلقائياء بمجرد كتابتك لبدايته 
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وضغط زر . .۲٥ع فمثلا: لو كتبت جملة.‎ 


If X = 0 Then 
فان محرر الكود سيضيف الجملة التالية تلقائيا:‎ 
End If 


بل إنك لو لم تكتب كلمة ٣٠ط‏ فسيكتبها لك محرر الكود تلقائيا! 

هذا بالإضافة إلى أنه سيضع موؤْشر الكتابة داخل مقطع ]| › وسيقوم بتنسيق المسافات البادئة تلقائياء بحيث يبدو الكود 
منظما وواضحا عند قراءته. 

كما أن هناك تحسيناتٍ كثيرة في تلميحات الشاشة التي تعرض قيم المتغيّرات وأنواعها ومعاملات الإجراءات والدوال 
وقيمَها المعادة. مع نبذة عن وظيفة كل دالة وكل معامل.. باختصار: لقد أصبحت كتابة الكود متعة. 


-هناك تحسینات کثیره في مظهر النموذج والأدوات» وهناك العديد من الخصائص والوسائل الجديدة التي تمت إضافتها 
لهذه العناصر› بحيث تمنحك تحگما آکبر فیھا.. فمثلاء أصبح بإمكانك تحديد درجة شفافية النموذج» كما صار بإمكانك 
تحدید المنطقة التي ستظهر منه على الشاشة. بحيث يمكنك تصميم نماذج بأي شكل. . ولم تعد مضطرًا لكتابة الكود الذي 
يحافظ على تناسب مقايیس الأدوات مع مقاييس النموذج كلما تغيّر حجم النموذج» فقد صارت هناك خصائص جاهزهة 
مسئولة عن هذا.. هذا بخلاف العديد من الأدوات الجديدة» مثل الفاصل Splitter‏ الذي يمگنك من تعغيير حجم الأدوات 
المتجاورة أثناء تشغيل البرنامج. 


۔صار بامكانك إضافة الأزرار والأدوات للنماذدج في وقت التنفيذ Run Tine‏ > مع قدرتك على ربطها بأي اجراء لیتم 
استدعاوّه عند ضغطها. 


لم يعد هناك أي قصور في مترجم الكود ءاام هه ٠‏ فكل لغات ۷5.۸11 تعمل على مترجم واحد» مما يعني أن ۷8 فد 
صار بقوة وسرعة وكفاءة ..+ ۷٥+‏ وكمثال» صار بإامكانك استخدام البرمجة الارتداديَة Recursive Programming‏ 
دون أن تخشى من بطنها أو استهلاكها لحجم الذاكرةء فقد صارت في منتهى السرعة والكفاءة. 

-أصبح بإمكانك معالجة الأخطاءء عن طريق استخدام معالجات الاستثناءات ersال‏ ۸2 "0نا xcepع‏ في جملة .. ر۲ 
Catch.. End Try.‏ 

6 مبنيْةً بالكامل على مفهوم البرمجة بالكائنات وہ¡ Object Oriented P02"‏ › لدرجة أن الأعداد 
الصحيحة !ntegers‏ والنصوص Si rings‏ والمصفوفات وره۸۲۲ قد صارت خلايا وsمووهاع‏ » وصارت لهذه العناصر 
خصائص ووسائل جاهزة.. فمثلاء أصبحت لديك وسائل جاهزة تنتمى للمتغير النصي› تسمح لك بالبحث فيه أو تقطيعه 
أو استبدال أجزاء منه... إلخ... كما صارت لديك وسائل جاهزة لعكس المصفوفة وترتيبها والبحث فيها! 


-صار بإمكانك استخدام کل مفاهیم الوراثة مہ ھ]ام۲ہ! وتعذد الأشکال ہءاطماه" راهم بلا أي مشاکل ..وإن کان 
مسموحا لك بوراثة خليّة واحدة فقط مء هاأمطم! ماوہاك للتسهيل. 

-يمنحك إطار العمل wok‏ مص ها۴ ه. ثروة هائلة من الخلايا ومووهاع › تقذر ب ٠٠٠٠١‏ خليةء تفعل كل ما تحلم به 
وأكثر» بحيث تريحك بدرجة كبيرة من الاحتياج لاستخدام دوال ۸۴١‏ الخاصة بالويندوز» بما فيها من تعقيد ومشاكل .. 
وأحدث ما فعلته (ميكروسوفت)» هو إصدار نسخة جديدة من ×1ء م1 مبنيّة بالكامل بالخلايا بدلا من.وإ۸۴ 

هذا بخلاف أن معظم هذه الخلايا قابل للوراثةء بما فیها الأدوات sاContro‏ نفسهاء مما يمنحك الفدرة على تطویر 
أدائها بما يناسبك . 


-ومن الخلايا الجاهزة العديدة التي يمكنك استخدامهاء الخلايا التي BitArray- Queue -: Stack‏ « ي ArrayList‏ 
وغیرها. 


أصبح بإمكانك تعريف المتغيّرات داخل مقاطع الجمل الشرطيَة وİ,‏ مهه ۴| والجمل التكرارية وم مها » بحيث تكون 
معزولة عن المتغيرات الموجودة خارج هذه المقاطع. 


-بل أصبح بإمكانك تعريف الخلايا داخل الخلايا ومووها٤‏ إم†ومN‏ » وأي نوع مما داخل أي نوع آخر. 


-أصبح بامكانك تعریف الواجهات Interfaces‏ وكتابة الخلايا التي تطبقها وتنفذها. 


أصبح بامكانك استخدام المندوب Delegate‏ کمعامل للاإجراءات والدوال»› بحيث يمكنك تمریر اسم أي إجراء أو دالة 
کمعامل! 
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j‏ أصبح بامكانك استخدام مٽ Attributes‏ في تعريف الخلايا والوسائل والخصائصضص والأآنواع المختلفة. مما يختصر 


لك الكثير من العمل» ويمنحك العديد من القدرات. 


و لديك إمكانيات جديدة وعديدة تمنحها لك خلايا جاهزة» للتعامل مع الملقات والمجلدات.. وعلى سبيل المثالء يمكنك أن 


تراقب أي تغییر يطراً على ملفات المجلد الذي ترید» باستخدام الأداة File System Watcher‏ › كما يمكنك أن تخزّن 
كائنا أو مصفوفة أو مجمو عة «هاءمااه٥‏ من أي نوع إلى ملف مرة واحدةء وإعادة قراءتها حينما تريد» باستخدام 
خلîيا‏ اldudۉ4. Serialization‏ 


١‏ -هناك إمكانيات هائلة في مجال الرسم والتلوين تمنحها لك مكتبة ..+ا62 يكفي أن تعرف أن بإمكانك الآن رسم 
منحنيات معفدة» وتكوين أشكال مركبة من مجموعة خطوط ومضلعات ومنحنيات» وتلوين السطوح بألوان متدرٴجةء 
وتحديد شكل مساحة الرسم» وتحديد درجة الشفافيةء وتدوير الرسوم وتغيير مقاييسها تكبيرا أو تصغيرا.... إلخ. 


١‏ -يمكنك استخدام المؤشرات "نمم في بعض الأحيان» للقراءة والكتابة في الذاكرةء كما يمكنك أداء عمليّات معقدة 


على النظام ورك لم تكن لتحلم بها! 


j‏ أصبح بامكانك تقسيم برنامجك لمجموعة من العمليات المستقلة وهههإ] » مما يعني أن برنامجك يستطيع القيام بأكثر 


من عمليّة في نفس ilئحزظMultithreading.Ã‏ 


-هناك إمكانيات جديدة رائعة للتعامل مع قواعد البيانات» تمنحها لك تقنية ا٥.۸50 ٠‏ بالإضافة للعديد من الأدوات 
المرئيّة التي تساعدك في إنشاء تطبيقات قواعد البيانات بأقل قدر من الكود. 


و أمًا الجديد تماماء فهو قدرتك على تصميم صفحات الإنترنت بنفس الطريقة التي تصمَم بها النماذج العاديةء مع كتابة 
كود ۷8 بمعظم إمكانياتهء لإنشاء تطبيقات ۸5۲ تعمل على الخوادم sم۷إم5‏ بدون كتابة حرف واحد من لغ A8۴!!‏ 


إصدارات الفیحوال بيسك دوت نت 


صدر أول إصدار لفيجوال بيسك .۸٥‏ (مایکروسوفت فیجوال بيسك 2002 ).۸٥۲‏ فی فبرایر ۲۰٠۰٠۲‏ و أصبح 
الاصدار الثانى (مايكروسوفت فيجوال بيسك 2003 ).۸٥‏ متوفرأً بشكل واسع فى مارس ۲٠٠۳‏ بعد فترة طويلة من 
التطوير و العمل الجماعى › أصدرت مايكروسوفت فيجوال بيسك eno‏ فى أواخر العام ۰.0 لقد أصبح فيجوال 
بيسك ۲٠٠٠١‏ مندمجاً الأن بشكل محكم مع الفيجوال ستديو لدرجة أنه يوفر فقط كمكون فى طقم البرمجة فيجوال 
بيسك ٠ ۲٠٠١‏ الذى يتضمن مصرفات لفيجوال #© و فيجوال ++ و الفيجوال #ل و أدوات تطوير مايكروسوفت 
.Net‏ و الاخرى لكن فيجوال ستديو e.0‏ يباع فى عدة نكاوين منتج مختلفة › من بينها الطبعة gy Standerd‏ 
النسخة اج 0اوومfهاP‏ و النسخة مااuں؟S‏ ”هه٠۲‏ و النسخة وو٠إم×ع‏ . و هناك عدد محددود بين الفروق فى 


النسخ السابقة و آنا انصحك بأستخدام برنامج 2005 ۷8.۸٥٤‏ صدار جديد 2008 Visual Basic .Net‏ 


متطلسات اللظام 


ستحتاج إلى الاجهزة و البرامج التالية لتحميل البرنامج 2005 ۷8.۸6٤‏ على الكمبيوترك الشخصى: 


أستخدام أنظمة التشغيل التالية. 
Windows XP Professional serves Pack 2‏ 
Windows XP Home Educat serves Pack 2‏ 
Windows server 2003 serves Pack 1‏ 
Windows server 2000 serves Pack 4‏ 
Windows Data center server‏ 
معالج بنتیوم ۰۰< میجاهرتز أو متوافق و سرعه ۱ میجا هرتز. 
۲٠‏ ميجا بايت ذاكرة و يفصل أن يكون اكثر. 
محرك أقراص مضغوطة او رقمية. 


شاشة (ذات دقة ۸٠٠*٠٠٠‏ ) أو أعلى مع آلوان ٠٠١٠‏ لوناً و يفضل أستخدام ( )۷٠۸ * ٠٠٠٠١‏ ألوان عالية ۳۲ بت . 
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موقع تكنولوجيا التحليم‎ 


ندعوك لزيارة موقع تكنولوجيا التعليم على الإنترنت على العنوان . 
sûal PT 4 1 3 www.salem4it.com‏ 
ستجد هناك شروحات عن كل كتبنا و مشاريعنا العمليه › كما يتضمن موفع 

تكنولوجيا التعليم شروحات عن برامج المحاكاة ثنائية الابعاد و ثلاثية الابعاد و 7 00 .)۷۷.538714 
البرمجة و الشبكات و الإنترنت و ا 


الأسئلة و التعليقات 


إذا كانت لديك أى تعليقات أو أسئلة أو أفكار تتعلق بهذا الكتاب أو الملفات التمارين أو الفيديوات على الأسطوانة 
المرفقه معه . الرجاء أرسالها على 


الیرید الا لکترونی ان -عE‏ منندی على لویب ء†Si Web‏ 
Mohamed youssef 1988@yahoo.com‏ 


www.salem4it.com Portsaid 2010@yahoo.com 
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الأهداف 


-۳ 


-۷ 


-۸ 


كيفية تثبيت الفيجوال بيسك ۲٠٠٠١‏ بكفاءة. 

تشغیل مایکروسوفت الفیجوال ستیديو .٠٠٠٠١‏ 

أستعمال بيئة تطوير الفيجوال ستيديو المندمجة. 

فتح و تشغيل برنامج الميكروسوفت الفيجوال بيسك دوت نت ٠٠٠٠١‏ . 
تغيير إعدادت الخصائص المشروع. 

نقل أطر الادوات و تغيير حجمها و أخفائها تلقائياً. 

كيفية أستعمال المصفوفات ضمن البرنامج. 

تخصيص إعدادت بنية التطوير المطابقة بالتعليمات. 

حفظ تغيرات › أنهاء التعامل مع الفيجوال بيسك دوت نت. 

التدريب على كتابة البرامج و تصميم الواجهة النموذج. 

التعرف على جميع قوائم البرنامج . 

فتح و أنشاء مشروع جديد فى بنية الدوت نت. 

التعرف على المتغيرات و الثوابت و التركيبات. 

شرح التعامل مع مكتبة ا٥۸50.۸‏ و ربطها بقواعد البيانات. 

الحصول على مصطلحات و القتموس بصورة سريعة بالغة العربية. 
التعرف على لغة _1ه» لاستخدامها مع ۸90.61 . 

كيفية عمل التقارير وامم ه۴ بصورة صحيحة. 

التعامل مع انشاء المشاريع البسيطة و الوصول إلى البرامج المتطورة. 
التعرف على جميع الادوات الخاصة و المميزة للفيجوال بيسك .٠٠٠٠‏ 
التعرف على الدوال و الوسائل الموجودة بالبرنامج. 

كيفية أنشاء و حذف و التعديل قواعد البيانات و الجداول. 

أستخدام جميع نوافذ البرنامج للتعامل معها فى البرمجة. 

معرفة تطورر البرامج و تقنية الدوت نت الحديثة. 

أستعمال أوامر المساعدة الجديدة و تخصيص المساعدة. 

الحصول على المساعدة عن طريق الإنترنت. 
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مقدمة کو الدوت نت‎ 
Framework مفهوم الدوت نت و فائدتة ومكوناتة وايضاح مفهوم‎ 


ماهو مفهوم میکروسوفت دوت نت ؟ 


التكنولوجياالحديثة تتطور وتتغير بسرعة في كل مجالات الحياة وكذلك هو الحال في تكنلوجيا الكمبيوتر وبرمجتة واحيانا 
التكنولوجياالحديثة تکون من الابداع في مكان تجبرنا فية لتحدي ابسط افتراضیاتنا وفي صناعة الحاسبات» كان اخر 


واعظمابداع هي تكنلوجيا الإنترنت تلك التقنية التي غیرت اوج العالم اقتصاديأً وثقافياً واثرت العلم في شتى مجالاته ومع هكذا 
تقنيةنجبر لإعادة التفكير كيف ستكون البرامج و كيفية تطويرها واستعمالها في ظل هذة التكنولوجيا.رغم ان هذة العملية تحتاج 
للوقت عادتأ وفي ظل مجئ تكنلوجيا قوية كانت اول عقبة هيربط شبكة الإنترنت بمنصة عمل حيوية تعمل خصيصا من اجلها 
وقبل مجئ ميكروسوفت كان المطورين يستخدمون منصات عمل قديمةفي ظل الامكانيات الجديدة للانترنت.وقبل عدة سنوات 
قررت ميكروسوفت ان الوقت قد حان لعمل تقنية جديد من اجل تاسيس عالم مابعد النت النتيجة التى ظهرت .١٠‏ وهي تمثل 
نقطة انتقال جذري في عالم برمجيات ميكروسوفت.اصبحت .۸٥‏ مسقبل مايكروسوفت الان فقد اعلنت ان اغلب ابحاثها 
وتطويرانها ستكون على هذة التقنية.ومن المتوقع بعد فترة ليست بطويلة ان تكون كل منتجات مايكروسوف معمولة على 
هذااساس ]ه۸ مايكروسوفت الآن اصدرت الاصدار الثاني لها 2.0 of Mior oso ..٤7‏ وبيئة التطوير تدعى Sudo‏ اVisua‏ 
5 واصدار الفجول بيسك الجديد يد عى 2005 عأوج8 اجمuء۷i‏ 


lھş .NET‏ ؟ 


ميكروسوفت . ۸٥‏ تقنية واسعة النطاق وطموحة جدا. وهي تشمل )امس هه۴۲ ۲.. .التي تشتمل على اللغات وتنفيذ قواعد 
العمل » بالاضافة الى طبقة واسعة من المكتبات ءهاإهإطا ووهام » وهي غنه بالمكتبات الداخلية . بالاإضافة الى النواة ×٤‏ 
.۴ramewor)kبالاضافة‏ الى تقديم مستوى متكامل للبرمجيات عبر شبكة الإنترنت . وتقديم خدمات للشبكة بما يعرف ط٥۷‏ 
‰5 وسوف ناتي الى تفصيل هذا المفهوم بالكامل. 


اهداف مایکروسوفت: 


قامت شركة مايكروسوفت بعمل تقنية الدوت نت بتكلفة مليارات الدولارات و تحتوى على اكثر من ١‏ الالاف مكتبة لأنشاء 
العديد من البرامج كتى يتوافق برامج الويندوز على انظمة اللينكس . حققت مايكروسوفت في هذة التقنية الكثير من الاهداف 
التى ظلت لفترة تحاول تقديمها بلغة ۷8 اصبحت لغة اشكال بالكامل 060۲ وبيئة التطوير بين لغات البرمجة مباشرة تماما حتى 
انة يمكن مزج الشفرات في نفس البرنامج .كما تم مواجهة تحدي كابوس لغة الجافا ۸۷۸ل بلغة سي شارب مع معمارية اطار 
العمل )امس مه۴ كما صارت معضلة صعوبة تطوير تطبيقات الشبكة العنكبوتية امر في غاية السهولة بالاضافة لاستيعاب 
تقنيات حديثة مثل 41× وخدمات عبر الشبكة وتم توحيد الكثير من الخطط الخاصة بشبكة في المنتج الذي سيصبح محور 
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تطویر تقبية دوت نت: 


کان ظهور النموذج الاولي لتقنية الدوت نت في مؤتمر المطورين في يوليو ۲ ۰ وعلی اساس انة يتم اصدارها في بداية 
٠٠۳‏ وقد حلت هذة التقنية محل تقنياتعديدة حاولت من خلالها ميكروسوفت ان تلحق موجه الشبكة العالمية للمعلومات مثل 
ر ۸S۶‏ الذي حل محلة 5P٤‏ المحسن .واستدعاءات ۸۲١‏ مثل ۸11 و ۴٥‏ بمجموعة متناغمة من فثات موج8 
اع وقد تم التنازل عن تقنية 5۸۸ لصالح التقنية الجديدة2.0 C00+‏ محل سابقتها وهي مختلفة عن سابقتها كما تم اعادة 
بناء لغة ۷8 لتصبح لغة اشكال كاملة 00۴ وتم استحداث لغة برمجية جديدة تمزجبين سهولة الفجول بيسك وقوة ++ ٥‏ تسمى 
السي شارب# ولتضمن الشركة انتشارها تم جعلها مفتوحÎ‏ |أaصدرSOURCE OPEN‏ 

ومن المفيد الاشارة انة تم التغلب على اشكالية تعدد النسخ من المکتبات یا٣‏ "هم ٥٥"‏ والتنازل عن استخدام مخزن البیانات 
العام راءاوم واستخدام تقنية 01× وتفنية 50۸۳ في عملية تطوير التطبيقاتالخاصة بالشبكة العالمية وخصوصا خدمات 
عبر lئڊكة Web Services‏ الواقع ان هذة التقنية حيوية جدا لشركة مايكروسوفت التى تحاول الانتقالمن توجهها الحالي ببيع 
الوحدات والنسخ الى تقنية التأجير والخدمة للحفاظعلى مكانتها في المقدمة حيث ان التوجة يعاني من الكثير من الاشكاليات كما 
ان مستوى مبيعاتها يعاني من الضعف والانخفاض المستمر. 


اهمية تقنية الدوت نت: .×٤۲‏ 


وقد بدات القصة منذ عام ۲۰٠۰٠۰‏ عندما اعلن بيل قيتس في موتمر المطورينالمحترفين ٥0ع‏ في ولاية فلوريدا ةذ هي الولايات 
المتحدة عن تبني مایکروسوفتللدوت نت (کانت تسمی وقتها الجيل الجديد لخدمات النواف 

Next Generation Windows Services )‏ كتقنية للالفية الثالثة والتى بدات في الاساس كتطور لمزود البيانات4 15| وتطور 
لادوات التطوير ۷57 في عام ٨۸‏ وقد ذکر بیل قیتس ان %۸۰ من مصادر میکروسوفت سوف تنفق في اتجاة دعمهذة 
التقنية الجديدة. وبعد ذلك بثلاث اشهر قامت ميكروسوفت بشراء 135مليون دولار من الاسهم غير المصوتة من اجل انقاذ 
شركة كورال وذلك لجعل الشركة تقوم بتقديم فكرة الدوت نت الى نظام اللينكس عن طريقك ورال لينكس وهذا ما حدث فعلا. 


اهمية الشكة الدولية للانترنت: 


ان انفاق شركة في عالم البرمجيات ۰ من مواردها في سبیل د عمهذة التقنية لابعذ يعني الا جديتها وايمانها بقدرة هذة التقنية 


على التحكم بالمستقبل. 
خصوصأ اذا علمنا ان السيولة المادية الحالية لدي مايكروسوفت اكثرمن مجموع اموال اكبر مئة شركة من شركات العالم 
البرمجية معا. 


هذة التقنية الجديدة اساسها الإنترنت والمهم ملاحظة اهمية الإنترنت المتزايد في عالمنا حاليا فقد اوجد لنا حياة جديدة تماما. 
ولقد اثبتت الخبرة في مجال التجارة الالكترونية ان فعالية منتجات الإنترنت تتناسب طرديا مع القدرة على الابقاء على الاتصال 
بالزبائن. أي اننا ملزمين بابقاء رابطة الوصل بينننا وبن زبون موقعنا. 


خدمات عبر الشبكة الدولية (الإنترنت) 


ان عملية تطوير البرامج وتحديثها عملية مهمة لكل منتج برمجي وذلكلما يشهد العالم من احتياجات تتطور تبعا لمتغيرات 
اخری وان مندون الدعم الفني والتحديتات للبرامج من المكن ان يفقد المنتجثقتة عن الزبون عند حاجتة لتحديث ما على 
برنامجة فلا يجدةمماً يجعلة يبحث عن بديل اخر مناسب ومن هنا تاتي الحاجةالى مفهومالبرمجيات كخدمات ٥إaس]fهS‏ 
vice‏ eوتقوم‏ بيئة الدوت نت د بتقدیم هذا المفهوم باستخدام سواب 

Simple Object Access Protocol‏ بروتوكول تداول الكائنات البسيط مهه5 وهو برتكول بسيطولكن قوي حيث يستعمل 
تقنية موجودة اصلا وهي تقنية 1۲۲۲۴ ويتجاوز مسأوئ التقنيات الحالية مثل الکوبرا C08۸۸‏ والدوت كوم 000. اللتان 
تتطلبانشروطا خاصة. 
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.×٤ تقنية الدوت نت:‎ 


تقنية الدوت نت .۸٤1‏ هي عبارة عن حل متكامل ومتطور من شركة مايكروسوفت لبناء الانظمة وتشغيلها للجيل القادم من 
التطبيقات والاجهزة والتى تسمج بعملية ربطالاجهزة والناس والمعلومات والشبكات في كل مكان بطريقة سهلة وامنة ومنظمة. 
هذة التقنية هي في الواقع تطوير وتجميع للتقنيات السابقة من انظمة التشغيل س٥ل‏ ہ۷۷1 وادوات التطویر ۷8 ومزودات 
الشبكات , A5۲‏ 5|| تم جمعها في بوتقة واحدة باسم تقنية الدوت نت الموجهه بالاساس لانتاج التطبيقاتللشبكة الدولية وانتاج 
خدمات عبر الشبكة ومءا»امS‏ ط٥۷‏ في هيئة 01× بواسطة معيار النقل. مه5 كما تعتبر احدث بيئة تطوير انتجتها 
مايكروسوفت كما ان حزمة البرمجة الجديدة 0.۸6ألںا؟ اعںء۷هي الاداة الرئيسية لتطوير الانظمة لهذة البيئة الجديدة. 
الواقع ان التوجه الجديد الذي تنتهجة مايكروسوفت هو التوجة نحوالشبكة الدولية (الإنترنت) . وبما ان البيئة المسيطرة علة 
هذاالقطاع هي بيئة جافا ۸۷۸ل فكان يلزم على الشركة ان تنتج منتج منافسلتقنية الجافا . والدوت نت هي تقنية مشابهه لتقنية 
الجافا. 

فمثلا لغة سي شارب # تعادل لغة جافا بينما هيكلية الدوت نت kامسهم"”‏ ه٣۴‏ تعادل مشغل برامج الجافا الافتراضي اھں)١۷‏ 

Machine .‏ وھذا يعني باختصار ان مایکروسوفت لم تقدم تقنية جديدة انما عملت على الاستفادة من افضل التقنيات الموجودة 
واضافت اليها (كالعادة) 


ما سب أختيار منتج الفيحوال بيسك دوت نٽ 


رأيي هو ان تستخدم الإصدارة ٠٠٠٠٥‏ وذلك لعدة أسباب. 


هي بداية أصدارة أحدث من الإصدارة فجوال نت ۲٠٠۳‏ وفيها أمور لا توجد بالاصدارة ۲٠٠۳‏ كما أنني لا أعلم كثيراً عن 
الإصدارة ۲١١۸‏ والمعدة للعمل على Vista Windows‏ 


ولكن لا انصح بها ولسبب واحد وبرأيي هو كاف. 

الاصدارة ۲۰۰۸ تستخدم 3.5 kامسعء‏ ,ه۴ والذي ليس له وجود على ۰ من الاجهزة على الاقل حتى الان» والاصدارة 
٠٠‏ تستخدم ال 0.2 kإمس‏ ع ه۴۲ والذي يوجد على %٠۹١0‏ من الاجهزة تقريباً الموجودة الان» أي أنك لست حتى في 
حاجة الى ان ترفق ال kامسعءمص_هإ۴‏ مع مشروعك لدى تسلميه الى المستخدم. 


حقيقة ان الإصدارة ۲١٠۸‏ تحتاج الى المزيد من الوقت» ذلك الوقت الذي يصبح فيه p×-ئ‏ س 1,0 كما ا 98 Windows‏ 


مع ان هناك ملاحظة صغيرة وهي أنني صنعت برنامجاً يعتمد على ال 1.1 kاw0‏ ھ٣۴‏ وعمل على أحسن مايرام على 


الاصدارة 0.2 Framework‏ واعتقد ان استخدام برنامج على اصدارة الفجوال ۲٠۰٠١۸‏ سوف تعمل طبيعياً على اصدارة ال 
٠,۲ Framework‏ بحاله واحدة وهي عدم استخدام مكتبات جديدة لا توجد الا بالاإصدارة 3.5 Framework‏ 


۱۹ 
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.Net Framework Jalil مقدمة أطار‎ 


.Net Framework Jaa | اطار‎ 


هو عبارة عن اطار يغطي كل طبقات تطوير البرامج اعلى من مستوى نظام التشغيلويعمل كبيئة تشغيلية لتنفيذ وتشغيل وادارة 
التطبيقات المصصمة للعمل تحت تحت بيئتة وتوفير مكتبات موحدة للتطوير مما يسهل انتاج التطبيقات مهما تعددت اللغات 
Net Framework‏ .حقیقتا يقو م تغطية او حجب نظام التشغيل اي يقوم بعزلالبرامج المصممة للعمل تحت تحت بيئتة عن نظام 
التشغيل وبشكل خاص في الامور التى تتعلق بادارة الملفات وتخصيص الذاكرةوقد صمم لتبسيط تطوير التطبيقات في البيئة 
الموزعة جدا(الإنترنت) ويجهز لجعل عملة في جميع انظمة التشغيل والمكونات الاساسية لاطار عمل نت يوضح بالصورة 
التالبة 


ASP.NET Windows Forms 


Web Services Web Forms ontrols Orawirniğ 


ASP.NET Application Services Windows Application Services 


NET Framework Base Classes 


Lomrmon Langage Runtime 


Mermory Management Lormrmon Type System Lifecycle Monitoring 


اهداف الاطار: 


توفير بيئة برمجة موجهه للكائنات 00۴ ثلبتة سواء كان التطبيق يخزن وينفذ محليام م )»وم او ينفذ محليا لكن موزع على 
الإنترنت 4ع uطاإ)وا‏ او تنفيذ عن بعد م†هم" R٠‏ او لتزويد بيئنة ذكية لادارة الذاكرة والمصادر وحل مشكلةّوماہهاءام۷ 
ولتزويد بيئة تنظيف رمز وهي التى تزيل مشاكل اداء كتابة او ترجمة البيئاتولجعل تجربة المطور ثابتة عبر الانواع المختلفة 
جدا من الطلبات مثلطلبات اساسها النوافذ والطلبات على الإنترنت.كما تعمل لبناء اتصال على معايير قياسية لضمان عمل ذلك 
المكونة مستند على اطار العمل بحيث يستطيع التكامل مع المكونات الاخرىوهو يتكون من عنصرين هما : المكتبات وبيئة 
التشغيل ويحتوى هيكل .١٥‏ على ما يزيد عن 3400 طبقة يمكن استخدامها في متطلباتك تمثل بعض هذة الطبقات انواع 
البيانات الاساسية واغلبية الطبقات مخصصة لمهام متخصصة اكثر مثب العمل بنظام الملفات وتوليد وثائق “× 


Common Language Runtime - CLR 


هو اول مكون لبنية اطار )مس مه۴ .۸٥1‏ ويطلق علية بيئة العمل المشترك وبة يتم تنفيذ كل التطبيقات ويتيح لك مزايا 
عديدة منها التعامل مع الاخطاء والامان وازالة العيوب والتناسق في ملامح البرنامج وهذة المزايا متوفرة لاي لغة مصممة 
لوظائف C1۸‏ وھذا TOO PES‏ عدد كبير من اللغات ويعرض مجموعات عامة من الادوات تشترك 
فیها جمیع هذة اللغات ولقد دعمت مایکروسوفت لعغات ۷B,٤C++,٥C#‏ بمکونات C1۸‏ وقد سجلت الشركات اسمائها لتقديم 
تطبیقات للغات الاخری متل ,۸0ر٥‏ ,امم بل وحتى . امطه٥‏ يصير هذا الكود كوداً مدارأم 1ع فعندما يحول المترجم الكود 
الى مكونات 01۸ والمقصود بالكود المدار هو الكود الذي يستفيد من الخدمات التي تقدمها مكونات وحتى يعمل وقت التنفيذ مع 
الكود لابد ان يحتوي هذا الكود على مايسمى بالميتادات|l Metadata‏ وهي عبارة عن بيانات يتم تخليقها اتناء تنفيذ المترجمات 
لعملية التحويل الى مكونات C1۸‏ وتخزين الميتاداتا مع الكود المحول وتحتوي على بيانات بشان انواع واضاء ومراجع الكود 
وتستخدم مكونات 1۸ الميتاداتا لتحديد الفنات sمءوهاع‏ وتحميلها وانشاء كود اصيل وزيادة مستويات الامان ويوجد فوق 
مكتبة الصنف القاعدي الاساسي نوذجان برمجيان. 

ASP.NET ıiتl الذي یستخدم لانشاء تطبيقات معتمدة على ويب ويمكن اذكر مابين المزايا العديدة‎ ۸5۲.۸6٤ الاول هو‎ -١ 
ميزة صفحات المزود الفعالة المترجمة وعناصر التحكم بالمزود الجديدة وخدمات ونماذج ويب التى تفصل منطق لغة النصوص‎ 


اا 
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البرمجية عن لغة وصف الاظهار‎ 
في البرمجة المعتمدة على‎ ٠ الثاني هو اطارات ويندوز حيث ياخذ هذا النموذج البرمجي باسلوب لغة فيجوال بيسك‎ -۲ 
وتعد اطارات‎ ٥ الاطارات ليعممها على كل مطوري تطبيقات وندوز ويتم هذا بواسطة مجموعة من الإصناف في اطار عمل‎ 
ويندوز مجموعة كاملة من الانماط القابلة لاعادة الاستخدام وهي تبسط تطوير واجهات الاستخدام الرسومية في ويندوز‎ 
وتسمح اطارات ويندوز بذلك ببناء التطبيقات سريعا التى تمتاز باستخدام عناصر اكتيف اكس ×٥«ء۸ والقوائم المنبثقة‎ 
والمكونات القياسية لواجهة الاستخدام الرسومية مثل الازرار ودوائر الاختيار‎ .٤ وامكانية الوصول الى مزايا الامن في‎ 
للوصول الی البیانات‎ ۸4٥.۸6۲ لہا۷ من کل مزایا‎ ٥ ws ۴۲ھ۳٥‎ , وسییتفید التطبیق لدي استخدم اطارات ویندوز‎ 
وسيستفيد التطبيق ايضا من احداث اصدارات واجهة الاستخدام الرسومية +ا65 وكذلك من خدمات الطباعة بحيث يغدو‎ 
التطبيق قادرا على اصدار التقارير الشاملة‎ 


Class Library 


lass Libary‏ تعتبر المكون الثاني لاطار )مس مصه۴ .۸٥‏ وهي المكتبات المساعدة والتى تساعد المبرمجين لانشاء 
التطبيقات وتحتوي بيئة الدوت نت على الالف منها وهي موزعة في مجموعات هرمية بهيكل . وعلى سبيل المثال كل 
الفئات التي تعمل مع نظام الملفات تجمع في تفرع الاسماء ص٠هاءرك.10‏ ويمكن ان تشير الى أي فئة بشكل معين في هيكل ام١‏ 
وذلك بكتابة اسم الفئة ثم اسم التفرع على سبيل المثال للاشارة الى تفرع الملفات في الفئة IO.System‏ يمكنك ان تستخدم 
التفرع ٥١أ۳".۴هاءرك.0|‏ هنالك فئنة واحدة مهمة جدا خصوصا لبرمجة صفحات 

Syste n.Web يمكن ان توجد تحت الف‎ ۸5۲.۸٥1 وکل الطبقات التی تتعلق بھیکل‎ SP. 


iesاbصAssem‏ غات المکتات 
الطبقات في هيكل ال ۸1. تجمع في ملفات تسمي ءءiاط۳‏ ءءء ومن المهم عدم الخلط بين الملفات 


Assemblies‏ وبين الفئات فالملف iesاAssemb‏ هو الملف او الملفات الفعلية التى تحتوي على الكود للطبقات الفئات على 
سبيل المتال كل الطبقات في الفئة ٠.10‏ ء1ءرك تقع في الملف ااه.طiامعءء"‏ وهو الملف الفعلي الموجود على قرص التخزين 


| AssEmbÎY Name Assembly File Purpose 

iE OE 1b mazar 1 EH, ALL ore Fy stern Types 
| yate Rya tem, AL1 CLR-specific system typES 
Syatem. Tata 3yatem, Dara. d11 AD. NET 


SALE, DICETEDE FIEFTItEE YALE, DiCESTOEYIECYISES AIL AEE DIFEBETOPY 


a yA Te, DE AH LE Syateam, DEAR A11 in dos graphics finictiorrality 


Fvatem . EDOTEILPDTiSETeTTITEA Fyatem.EHTLETpPFISETETTIiSE. ALL Services formerly known as COM+# 1.0 


ATE CET, HATIAEEHE TIE EY FT ET, HAEATEMETT , AL i Windows computer rnanagermernt 

j| System, HEZRA LE Fy TEM. HEART LEI. ALL MASE rmEssaQIng services 

Sas tam. Saa TES Syatem. Securit. d11 Programmatic security 

Sa CET. WEK Fate. VER, AL] ASF NET 

| Sateen. eb, FETYiTaA Fyatem. Yeb, FETT dL AAAIitioiA] eb gervice auUppOTE IoF 


ASF HET 


SYSTEM. VITUS FOF Fate, FimdoTa:. FOE. A1 i Windows Faorrns framework 
aya TET. ANI aya tem. ANL dE] FuppoEt TOE progEarmHinHg 1r Ertenaib 1s 


Harkup Language [(AML) 


Hizrfosoft .WisuasLlHssirc Hicreoaoft - Fis lEsaic. L1 isus] Hasic methods, constants, and 
mEtE 1ib tea 


۳ 
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الجزء الثاذ التعرف ڊرnli‏ 2005 Visual Basic.Net‏ 


طريقة تثبيت الفيجوال بيسك دوت نت ٠٠٠٠١‏ 


Microsoft Visual Basic 2005 Express Edition چaliرڊ‎ Jınحتل‎ 


TF aF FER 


TOS 


Visual Basicz 005‏ , ي 
E t Express Edition‏ 


16 ٤ ٤١ الصيغة 50| : الحجم:‎ 


بیئة 2005 ٥ہ. vb‏ أو کما یعرف ع 5| وهی أختضصار| آ integrated development environment‏ › والفیجوال بیسك دوت 


نت امم. vاوaط‏ امvisu‏ هى أحدى اللغات المتاحة داخل امہ.هioلںاء‏ اvisua‏ بالأضافة الى , visual c# .net , visual j# .net‏ 
visual c++.net‏ 


وبيئة أم.٥اووط‏ امuواا‏ هى بيئة متكاملة لأنشاء وتصحيح التطبيقات المتنو عة مثل ہهناه‌ااممه sسwس‏ ەلاس وغيرها من 
التطبيقات المختلفة. 


خطوات تنصيب البرنامج 


e Yısual Basic 200b Express Edition Betup كا‎ 3 


SE errs 
Visual BaSIC 2005 
Express Edition 


Salem4it.com 


WEISO E to the WIsSUal BDasIc ZULUS Express Edition Installation wizard, Wisual Basic 
Z2UU5 Express Is a llghtmwelght tool that makes It very eBasy to learn how to build 
rich Wwindoams applications, and to jaln a community of hobbrist programmers, This 
wizard will Şulde you through the process to Install this programm and any 
prerequisites needed on this cûrnputer, 


Help Improve Setup 
Tol Gan suUbrnit anonrrnous Information about your Yisulal Studio setup 


ExperFIeBNncEeES to Microsoft, To participate, check the box belovy, 


Yes, send information about my setup experiences to Microsoft Zorporatkion,‏ ا 
ITE : : : 7‏ 
li} For more Information, click Data Collection Policy‏ 


POWESEF . 


1٤ 
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iê vısual Basic 2UUb Express Edition Setup لك‎ 5) 


IESE 


End-User License Agreement | Visual Basic 2005 
Express Editior ) 
Salemadit.com press Edition 


ûccept the terms of the License Agreement to continUE, 


End User License Agreement 
Be sure to carefully read and understand all of the rights and restrictions 
described In the EULA, Tou will be asked to review and eIther accept ûr not 
accept the terrmis of the EULA, This product will not set up on your computer 
unless and until you accept the terms of the EULA. For your fUtUFE FEfEFENGE, 
yol mary print the text of the EULA from the eula txt file of this product, Toul 
may also receive a copy of this EULA by contacting the Microsoft subsIldlafy 
SeFYINQA ¥YOUrF country, ûr by writing to : Microsoft Sales Information 
enter dne Micrûsoft WayfRedfnond, WA 48052-63939, 
| 


I haYve read, understood, and agreed on the terms of the End-User LIcENSE 
ûqreernent and so slqnify b¥ clicking "I1 accept the terrns of the License Agreernent" 
and proceeding to se the product, 


t the terms of the License Agreement 


iayisual Basic 2005 Express Edition Setup 


e 


SEI 


` Installation Options Visual Basic 2005 
Salemadit.com Express Edition 


Select the optional productis} You would like to Install: 


2 Microsoft MSDN 2005 Express Edition alg ةي™کaلl‎ 


The MSOM Express Library contalns additional product documentation for all 
- isulal Studio Express Editlûns, Tou can choose to Install MSOM ExprFess 
Library at a later time, See the Readme for more Information, 


Microsoft SQL Server 2005 Express Edition الأسكول سیر گر 86ب‎ 


۳ TEAL Server Express is a basic version of Microsoft SQL Server that allows 
. yol to Easlly read, write, and deploy application data, 


the Readrne file,‏ ی 
ROSSER‏ 


1° 
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iaıyisual Basic 2005 Express Edition Setup 


ES E | Visual Basic 2005 
Salemaitft. lom Express Edition 


Select the location where you would like to Install Yisual Basic 20U05 Express 
Edition. 


Install ir Folder: 


Program Files\Microsoft Yisual Studia 81 


The Following products will be installed: 

Microsoft ET Framework 2,0 
Yisual Basic Z005 Express Edition سبيت القيجوال مع‎ 
Microsoft MSDN ZOD05 Express Edition الأدوات المهمة‎ 
Microsoft SOL Server 2UU05 Express Edition x36 اسيتم شر خها لاحها‎ 


Disk space requirements: C: 1.5 GB 
YOWSSEF | 


iê YIsual Basic 200 Express Edition Setup لگ‎ 3 


[ 0 hel Ei HE EE EE / 
ت‎ Visual Basic 2005 
GSGalemadit com Express Edition 


ThE ا و ا‎ terns) are being installed on this carnpukter: 
هنا يدا تتزيل البرتامج علينا الانتظار لكي يقوم بعمله وتوزيع ودمع اليرامج التالية‎ 


Microsoft NET Framework 2.0 

Yisual Basic Z005 Express Edition 

Microsoft MSDN Z005 Express Edition 
Microsoft SOL Server 2005 Express Edition x#Bû6 


Currently Installing (1 of 4}: Microsoft NET Framework ZA ,0 


ی 
YOWESSEF‏ 


lL. Cancel | 
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HB Stari Page - Microsoft Yisual Basic 2005 Express Edition 


File Edit Wiley Tools Window  Lommunity Help 
Start Page| ٤ Solution Explore 


ر © 


MCTOSOIE 


Visual BasIC2005 Salem4it.com 


Express Edition 


A 


Hecent Projects Yısual Basic Developer Hews 


The current news channel might nol be valid or: 
connection might bE unavailable. To change th 
on the Tools menu click Uptions, [hen expand E 2 
click Startup. 


انتهينا من عمل البرنامج واصيح جاهزا للاستخدام 


pen: Project... 
Lreale: Project... 


Getting Started 


How Dol... ? 
Whats Hew IM Wisual Basic ZOOS? 
Lreate Touûr First application 
Ise a Starker Kil 

Learn Yisual Bazlz 

Lonnect wth thE Corr urity 
Download Additonal Content 


| 171 | | 


x 


New Frojeci 2 × 


Termplates: oalemait.coım Hi 


Yısual Studio Installed templates 


WAS lass Library Lonsolê My Movil Scrêef Saver 
Applicaton Application Lollect... Starter Kil 


My Templates 


وشذه هي المكونات الرنيسية للبرنامج نلاحظ انه لايوجد اي لغة سوى لفة 


Search Unllne 
Templates... 


û project for creating an application with a wîndows user interface 


J YOWSSEF 
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٠٠٠٠١ التعرف على الواجهة الفيجوال بيسك‎ 


_ 


Microsoft 


' a Visual Studio 2065 


Integrated development environment - |DEۓفرzي‎ În gl 
VISUAL BASIC.NET 
VISUAL STUDIO.NE7مliربڊ‎ Jخاد هي احد اللغات المتاحة‎ 


بالاضافة الى 

VISUAL C#.NET 

VISUAL J#.NET 

VISUAL C++.NET 

وبینه BAS|.N٤‏ ا۸ل هي بيئة متكاملة لانشاء واختبار وتصحيح التطبيقات المتنوعة مثل 


WINDOWS APPLICATION 

WEB APPLICATION 

CLASSES AND CONTROL LIBRARY 
CONSOLE APPLICATION 


بالاضافة الى غيرها من التطبيقات 

مثل تطبيقات قواعد البيانات وتطبيقات الهواتف الذكيه..الخ 

وعند فتح برنامج S10 .N٤۲‏ ال للمرة الاولى سوف تظهر لك نافذة 

Choose Default Environmant Settings‏ وتظهر هذة النافذة اذا کنت محمل S۲1 510.N٤‏ ا۸ Uل۷/!S‏ فقط 
وهي لاختيار اللغة التي تريد ان تكون افتراضية عند دخولك الى 

SUL STUDIO.NET‏ فقم باختیار بیئۂ BAS1٥‏ ۷15۷10۸1 کما بالصورۃ 


9 Choose Default Environment Settin qs 
Microsoft 
Visual Studio 2005 


Before you begin uzing Wlsual Studio for the first Hme, pou eed fo specify the tppe of development 
activity pou EnAaãqE ir he most, such a3 Wisual Basic or Wisual CR. Yisual Studio uses thls 
information ta apply a predefined collection of szeltlngs to he development environment that [s3 
dEezlqred for pour deweloprient activity. 


Tou can choose to use a different collection of settings 
Import and E#port Settings and then choose Reset all 3 


Choose your defaull enyvironmenlt selling3z: 
REESE EÊ ûs il Description: 
1 5 2 | Optimizes the enwiranmeAt za you can FBEus or 
Wisual CH Development SettAGS building world-class applications. This collection of 
seings contalns cuztormlzallons lo he winda 
layout, command menus and kepboard shortcuts to 
make carmrmon Wlsual Bazll coammarfıdz rîore 
actesszlble. 


Start Weual Sada | E sit Wisual Stadio 


ثم قم بالضغط عذى jزر Start Visual Studio‏ 
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بعدها انتظر قليلا بينما يقوم الفيجوال بالقيام‎ 
START PAGE بعمل اعداد بداء العمل ثم سیظهر لك وڼ‎ 


E Win dora A pp lîran - lero soft 


| 


e |‏ ا چ و 


| RECENT FFEJCZtS Yim Shula OegelapEer 1e 


etn 
3 trai aj Fein Û i Î e aa 


Th Za efË rawr 2ha fren 
rejhF He ııqaw aile hile. 1n rf 
riffle a, Fh r emre Fraplie 


Tapeh E, e Ske 


E! Piet, [gz Eat 


Lii Larter 
anî ê Û... 


Fug E * FF 1 Yg EF a 
alal Tur Tal pL sla 
ءا‎ a واو‎ | 

aI zl Ez1 

ry ely mr Im 
nla ASU USE So TET 


وبها تظهر اخر تطبيقات تم انشائها او تعديلها 

ولكن هي لا تهمنا الان قم بالضغط على قائمة 

New Project lia تر‎ gy FILE 

وستظهر لك نافذة اءمزه٥‏ سه" لتختار منها التطبيق الذي تريد انشائة 
لاحظ هذة الصورة 


Mew PFrojecl 


3 Yîsual Baie | Yisual Studio installed ternplates 9 
7 EUS SLUOD IESE 
% - Smart Cek | >r 
0 MM A 8 © 
atatter kis lass Library  Cenede Wirdowms Wek Control 
Fi: oer Lar Aêû35 applicalien Co rol lbrary  Lirasy 


&. Gther Project Types 


@ 3 @ 


Windomes  EmpiyP"ojecl  Zreetal 
FE ILE Belles 4 


| __ Pir Templates 


YOUSSEIR‏ ا ب 


LH | WrdcusArphcat o1 


merem ETE 


على اليسار يوجد نوع المشروع الذي تريد انشاء احد تطبقاتة وعلى اليمين تظهر تطبيقات المشروع 


۱۹ 
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أنوا ع المشاريع: 
يمكنك أن ترى كل أنواع المشاريع المتاحة - بخلاف تطبيقات ويندوز - في مربع حوار "مشروع جديد"» وهي كالتالي: 


Class Library :اı !لخ‎ ةuتكکم‎ 


وهي مکون أساسي لبناء الكود» ليس لها واجهة مرئيةء ولكنها تؤّدى وظائف معينة لبرنامجك. 
وباختصار» فان الخلية هي مجموعة من الدوال والإجراءات التي يمكن إعادة استخدامها في أي مشروع» بحيث يوفر المبرمج 
على نفسه مشفة إعادة كتابتها مرة أخرى. 


Windows control library :ianis : مكنة ادات‎ 


إن أدة ويندوز - أو الأداة على سبيل الاختصار - هي عنصر أساسي في واجهة البرنامج» مثل مربع النص أو الزر. 

فإذا ما وجدت أن الأدوات التي يمنحها لك ۷8.۸٤۲‏ - وهي التي تظهر في مربع الأدوات تلقاتيا - لا تمنحك الوظيفة التي 
تريذهاء ففي هذه الحالة يمكثك أن تب تبنى الأدوات الخاصة بك. . إن هذا يبسنط عملك فيما بعد» حيث لن ثضيع المزيد من الوقت 
والجهد في تصميم أجزاء من واجهات تتكرر كثيرا. 

بل يصل بك الأمر لو كنت خبيرا في تصميم الأدوات الخاصة» إلى أنك تستطيع بيعها للشركات والمبرمجين ين الآخرين 
صفحات مجلات الكمبيوتر تزخرًُ بالإعلانات للعديد من الأدوات الخاصة المتطوٴرةء التي كمل عمل الأدوات الأصلية. ٠‏ 


Windows service خدمة ويىدوز:‎ 


وهو الاسم الجديد أ N‏ sمءviإمك‏ القديمة.. وهذا النوع من المشاريعء ما هو إلا برامج طويلة التشغيل تعمل في خلفية نظام 
التشغيل» دون أن تعرض واجهة مرئية. . ويمكن لهذه الخدمات أن تعمل تلقائيا بمجرد تشغيل الجهازء كما يمكن إيقافها لفترة ثم 


إعادة تشغيلها. 
إن البرنامج الذي يتفاعل الملفات على الجهاز ويغيرهاء هو مرشح رئيسي لأن يكون خدمة ويندوز» حيث يمكن لهذه الخدمة أن 
تؤدي ڊ بعض العمليات» فور أن ينقل المستخدم بعض الملفات إلى مجلد معين› كأن تنسخ الملفات أو تقرأً محتوياتهاء أو تحدث 


محويات قاعدة بيانات ...وهكذا. 


Console application تطبیق الاختبار:‎ 


وهو تطبيقٌ ذو واجهة استخدام محدودة جداء هي أقربُ ما تكونْ لشاشة الدوس 005 السوداءء حيث يتم فيها إخراج النواتج 
وإدخال البيانات» على سبيل اختبارها. 


ASP.NET Web Application :تنرتil'1 تطبيق‎ 


إن تطيبق الإنترنت هو واحد من أكثر السمات الجديدة في ۷/5.۸٣‏ إثارة» وهو عبارة عن برنامج يمكن تشغيله على شبكات 
الإنترنت» يمكن طلب خدمات معينة منه عن طريق متصفحات الشبكة.. وأوضح متال لذلك› هو محل كتب يعرض ویبیع على 


الإنترنت. 
ويجب على التطبيق الذي يعمل على الإنترنت أن يستقبل طلبات العملاء» ويرد عليها في صورة صفحة من صفحات الإنترنت 
HTML.‏ 


ومثل هذه التطبيقات ليست بجديدةء ولكن الجديد هو أن A5۲ .٤۲‏ صار يعزل المبرمج عن كثير من تفاصيل بنائهاء مانحًا 
الكثير من السهولة والسرعهة» ومحولا العمليه إلى ما يشبه كثيرا بناء تطبيقات ويندوز التقليديه. 
وسنناقش بالتفصيل خدمات وتطبيقات الإنترنت في آخر جزء من هذا الكتاب إن شاء الله. 


ASP.NET Web Service:i خدمة الاإنترز‎ 


وهي لا تکافئ بحال خدمات ویندوز» بل هي عبارۀ عن برنامج يعمل على خوادم الإنترنت ٣٥ S٥۷٥۶‏ ٣٥۲ہ|‏ لاستقبال 
الطلبات» تمامًَا مثل تطبيق الإنترنت» ولكن دون أن يرد بصفحة من صفحات الإنترنت» بل يرسل ناتج العملية الحسابيةء أو 


Prog : Mohamed Youssef 
المعلومات المطلوبة من قاعدة بيانات ماء وعادة ما تطلب هذه الخدمات من قبل خادم إنترنت آخرء حيث سيتولى هو التعامل مع‎ 
البيانات.‎ 
ولتوضيح الفارق نضرب هذا المثال:‎ 


إن تطبيق الإنترنت الذي يتلقى منك استعلامًا عن كل كتب (توفيق الحكيم) سيعرض لك صفحة عليها أسماء هذه الكتب.. أما 
خدمة الإنترنت التي تتلقى منك نفس هذا الاستعلام» فسترسل إليك ملف 01× يحتوي على أسماء الكتب المطلوبة» حيث يمكن 
لتطبيقك في هذه الحالة أن يتعامل مع البيانات ويعرضها في صفحة جديدة بالشكل الذي تريده» ويرسلها للمستخدم الذي تريده» 
أو ربما تعرضها على نموذج ويندوز عادي. 


Web Control Ii} rٽary:ٽنرتiإ'1 مكتبة أدوات تحكم‎ 


كما أنك تستطيع أن تبني أدوات الويندوز الخاصة بك لتستخدمها على نماذج ويندوز»ء تستطيع أيضًا أن تبني أدوات الإنترنت 
الخاصة لتستخدمها على نماذج وصفحات الإنترنت. 


مشاریع اخری: 
أما القوالب الثلاثة المتبقية في مربع حوار "مشروع جديد"» فهي: 
1- شرع lرğ. Empty Project‏ 
۲- شرع إiترنٽ‏ lرğ. Empty Web Project‏ 
۳- مشروع جدید قي مجiد‏ مgجıg. New Project In Existing Folder‏ 


وهي ليست أنواع مشاريع بالمعنى الفعلي» بل مجرد طريقة لتنظم مشاريعك الجديدة بنفسك» فحين تختار واحدا منهاء ينشئ 
7 مجلدا جديدا يحمل اسم المشروع» وينشئ فيه بعض الملفات القليلة التي يحتاجها البرنامج من هذا النوع.. وعلى 
عكس الأنواع الأولی ۔- حيث تقوم ۷5.٤۲‏ بإنشاء عناصر افتراضيْة والملفات اللازمة لهاء كإنشاء نموذج مبدئي في تطبيق 
ويندوز» وإنشاء أداة المستخدم في تطبيقات أدوات ويندوز ‏ تحمَلك هذه الأنواع الثلاثة مسئولية إنشاء وإضافة ما يلزمك من 
العناصر والملفات. 


حددناه وفي الاسفل النافذة اسم المشروع و يمكن ان نغيرة الى الاسم اللذي نريدة نختار الان احد تطبقات 
۷|[SUAL BASIC.NET‏ وسنختار من هذ lأdliذةö WINDOWS APPLICATION‏ 
ثم نضغط موافق سوف تظهر لنا قوائم وادوات ونوافذ لغ BAS|C.NET‏ اA‏ ل5 هکذا 


E Win lowysA pplication] ¬ Microsoft Yisual SI0dio 
Ell Eft Wem Project Buld Debug Lata Farmall Tools: Windom Lommurnity Help 


O e‏ ا حح 5 ج وھ اد کیا ا وا ا اا دت ف ا طا - لا جا لد 
S2 olution E splarer HM E‏ س ا | “Forml .¥b [Design]” | Start Page‏ 2 
Bl ê GLEE A‏ 
ator‏ عا pp‏ ھچیص ںا nd ın‏ أ 
My Project‏ | 
Ea] Forml.wb‏ 


E Solutior E #plorer a Lata SDUrCES 
Fropertiazs - HH 


Form] System. yYirndovwys. Forrns. Form = 


StatPaositian loys efa 
Tag 
Tent Form Î 
TopMost False ا‎ 
Text 
The test associated with the control. 


4 0# 234 


۲۹ 
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لاظهار قوائم الخصائص او الادوات نقوم بوضع المؤشر على اسماء القوائم الموجودةلاظهار نافذة الادوات من القائمة س٥۷‏ 
واختر × 168مه] او بالضغط عİذXJ+Alt Cirl+‏ واذا ظهرت النافذة بشكل منطوي د تحت احد جوانب نافذة الفيجوال ستديوما علينا 
الا الضغط على الزر الاوسط الموجود في اعلى أي نافذة الذي بهذا الشكل 


وبعد تثبيت قائمة الادوات سيظهر شكل الواجهه هكذا 


9 YindowsApplicationl - Microsoft Yisual Studio 
File Edl Wiew Project Build Debug Uala Fama! Iools Windom Lommurnily Help 


CER DT IEEE ا س س‎ 


Toalbox HX ا‎ Solution Explorer 


|3 All Windows ... ^| ھا‎ 3 Ell 3 3 
أ‎ | E Form] TEAS | ا‎ im doweApplicatidil 7 
: || 7 Edl] My Project 
. CE] Forml.sb 


EES gD ata Sou. 1 


HH Î ê E W 


۰ ` Properties HM E 


Forml System. windows. Forn 


IKI 
12 
ا‎ 


IZ I 


SIE rIpS HY „Auto تش‎ 
StartPoasilor WIndomslU efa 
Tag 
Test Form] 
TopmMost False 

Transnarenrl Î‏ کح 
Text‏ 


The tent associated mith the 
control. 


E Ê ê Û 


3 21229 


وفي الجهه اليسرى تظهر قائمة الادوات وسوف نتعرف على کل اداه موجودة بها في الدروس القادمة 


ویظهر بالجهه الیمنی نافذة orerام×E‏ ionاuامS‏ واسفل منھا نافذة الخصائصض5٥]‏ ٥م٥٣۴‏ 


۲۲ 
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ولکن ما ھو الفرق بین ٢٥‌ااں‌اه5‏ ( المشروع ) وال ( c۲‏ ءزہإم التطبیق) ؟ 
اءەزدPr‏ او التطبيق: 
هو عبارة عن محتوى للمكونات الخاصة بتطبيق ما مثل النماذج ء٠۲٠۴‏ وكتل الا كواد البرمجية 
Classes yİ Modules Jl‏ 
ومع بداية ظهور لغة م.۸.ط۷ ظهر ما يسمي) n‏ oناں‌ام5‏ المشروع) وفائدته تنظيمية للوا‌مزه۴۲ 
ويعتبر أل ہoاuاهS‏ مساحة العمل الخاصة بالدوت نت فمن الممكن ان يحتوي على اكثر 
من تطبيق زه بداخلة وتستطيع ايضا اضافة مكونات خارجة عن أطار الکود الی ٣٥نtں‌اه5‏ أي حتی ولو لم تتعلق بكود 
التطبيق كملف وورد أو صورة او ملف صوتي وبالتالي تستطيع استخدامها داخل تطبيق الدوت نت توجد النافذة ر u†oاهمS‏ 


٣eدام»xع‏ في الجهة اليمني كما يمكن اظهارها من قانمة سه۷ او بالضغط على ۲+1ا۸+اإ]٥‏ وتعمل على عرض عناصر 
ومكونات التطبيق على هيئة قائمة شجرية في اعلي القائمة يظهر اسم التطبيق الحالي ويليه بقية مكونات التطبيق 


5 و‎ E «plorer 


۱ a a 
ا‎ 


i bin 


ا ا 8 


ونستطيع اضافة عناصر الى التطبيق الحالى من خلال النافذة Solution Explorer‏ وذلك بالضغط على اسم المشروع بزر 
الماوس الايمن ثم ل۸ ومن نختار mءit| New‏ 


j| Eodsting er... Add Reference... 
New Folder Add Web Reference... 
(E) Windows Form... | | Wert Class Disgratm 

Î User Control... Debug ع‎ 
dj Component... HF Add Project to Source Control... 
7 


ھک 


۲۳ 
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Add New Item öةذفان سوف تظھر لن|‎ ۸٥W ا٥۳ وبعد الضغط علی‎ 


Adi Hew termî - Hm dT Ap pire Bia rî 


Templates! 
Yisıal Shudio installed templates 


و ك و 1 E‏ 


Explorer Formi MIM Farerê Abo ijk Box Login Faîmi plazh Steer 
Farm 


2) 1 1 e 1 


linker ate Component COM lass DaktaSet SL Cektabase Report Crystal Report 
lass 


eer Control Irherbed Ect Inher edl Le bot 
onir ol or irl 
A blank Windows Form 


Marui: FoF TE Yb 


وبها العدید من تطبیقات 5۲0۱0.۸٤‏ ا۸ل نختار منها ما نريد اضافتة الى تطبقنا الحالي 
Windows Fm‏ وھنا مثلا سوف نختار 


قم بالتاشير علية ويمكننا تغيير اسم التطبيق قبل اضافتة من اسفل نافذة ٠اا‏ سم ۸4١‏ او نتركة كما هو ثم نضغط على الزر 
فنلاحظ اضافة ۴٥۲‏ اخرى الى التطبيق تاخذ الاسم ۲ ۴٠۲۳”‏ وتظهر في lئnمة Solution Explorer‏ 


كما بالصورة 
COTE TES‏ 
١ =‏ 1 | 
aan‏ 
E} WindowsApplication1‏ 
My Project‏ ت 


=3] Form1.vb 
2] Forma.vb 


۲٤ 
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التعرف على القوائم ںم م"‎ 
Menus With Visual Basic.Net 2005 


اليوم سوف نقوم بالتعرف على قوائم الفجول بيسك دوت نت ١٠٠٠۲تتكون‏ قوائم الفجول بيسك دوت نت من ازرار عديدة لها 
مهام مختلفة والازرارموضوعة على القوائم المخصصة لمهامها وسوف نتعرف على عمل معظم ازرارهذة القوائم او بقول اخر 
سوف نتعرف على اهم ازرار قوائم الفجول بيسك دوت نتوذلك للتعامل بسهولة مع واجهة الفيجول بيسك كذلك لمعرفة قدرات 
هذة اللغة القويةقد تلاحظون في صور الشرح التي وضعتها بهذا الدرس اختلاف بين قوائمكم وهذة القوائم اختلاف ترتيبالازرار 
او وجود ازرار اكثر بقوائميلا تخافوا يمكننا تعديل قوائم الفجول بيسك دوت نت من حذف واضافة وترتيب الازراربما يناسب 
متطلباتنا واحتياجتنا وذلك من القائمۂ sامہ٣‏ قم باختيار مzاہہاوں‏ ستظهر لك نافذة قم باختيار التبويب الثاني وستظهر لك 
كل قوئم الفيجول بالجانب الايسر وبالجانب الايمن يوجد ازرار القوائم قم باختيار أي قائمة ثم من ومن الجانب الايمن قم بعملية 
السحب والافلات للازرار التي تربد الى القوائم اللتي تربد ومتی تنتهي قم باغلاق النافذة Customize‏ ولقد قمت بتقسیم هذا 
الدرس الى جزئين والان فالنبدا مع الجزء الاول ومع اولى القوائم بالفجول بيسك نت 


[File] 


وتتكکون من ازرار الإوامر التي تتعامل مع انشاء وفتح وحفظ واغلاق كلا من الملفات والمشاريع 


WS WYindowsApplicationl - Microsoft Yisual Studio 

E ıt Buld Uebug Uala Iools: Windom LL 
0 Mew Project... 1 Ltrl+f! 

pen F FF  Hew'web Site... @ټ‎ 

Ade | Fe... © atior 


Yew Project 


Prapect Fram Emsting Lode... 


Llose 
Llaze Prapect 
ave Foml.yb Ltrl+5s 
ave Forml.yb Az... 


ave All Ltrs hift+h 


Export Ternplate... 


Tource Control 


Fage Setup... 


[- انشاء مشرو ع ا۷ا جذید 
انشاء تطبق انترنت جذند 
انشا ملف نتس او زسوهی الح 


Print... Ltrl+F 


Recent Files 
Recent Projects 


E ıt 


Yo 
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a YYindowsApplicationl - Microsoft Yisual Studio 
E dit 


Yew Project Buld Uebug DUala Tools: Window  Lomrmuniyp F 


J ey a : ا‎ # il 


Orn PF ÎÎ OpenPriect.. Cu _ @ 
Add + Ê Openweb Sie... @ | 


E? Open Fils... 3 


Lloze 


| Llasze Propect 
lÎ Save Foml.sb Ctrl+S 


awe Forml.wb As... 


E  Savedl CtrleShift4S 


Export Teriplatë... 
Source Lontrol 
فتح مشروع ا۷ سایق‎ -1 
قتح تطبیق انترنت ساپق‎ -2 
Recent Files فتح اي نوع من انواع الملفات‎ -3 
Recent Frojects 


E ıt 


File | Edt  Yiew  Propect  Buld Debug Uala Tools Windom  Lorimu 


e ا ا د3 اء‎ j 


pen ۴ 


a 


Cloze 1 


i] Llose Pro|ect 
WÎ Save Foml.sb Ctrl 0 


Save Forml.yb Ãz... 4 | 
Î SavedAl cms @ 


E«part Ternplate... O 


1- غل الصلف الصحدد ۴ Source Lontrol‏ 
2- علق كامل للمشروع 

3- حفظ التخيرات على القورم 

4- حفظ الفورم كملف اخر جديد 0 
5 حفظ جميه التغبيرات بالمشروع ۴ Recent Files‏ 
استخراج #عنصر او گل عناصر 
الفسرويع وضقطها وحفظها 

ا“ تخداد بوقت ار @ E «ıt‏ 
7- اغلاق الفجول دوت ثت 


Recent Frojects ۴ 


۲٦ 
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[Edit] 


تحتوي هذه القائمة على الازرار القياسية التي تعمل على الالغاء والتراجع والنسخ والقص واللصق 
والحذف وتتJala text and other objects.ga‏ 


E YindowsApplicationl - Microsoft Yisual Studio 


File | Ed Wie Project Buld Uebug Uala Tools Windom Lommunik 


E 1خ ا‎ 
a EFE anl Ctrl+ 

Es 

۴.1 Lelate Leal î 
Find and Replace ۴ 
lana Ta... 
Select ۉۇ؛ll‎ Ltrl+ك‎ 
Insert File As Tet... ]2[ يتنشحل شذا الخبار بجد‎ -1 
AdYarcEed ۴ ات نص بباستخداصة تستطيد‎ 
El استتجا دد‎ 

ook marks ۴ E 

NS n 
Intell erse ۴ صقا‎ 
Heamt Method Ltrl+FaUr 
Previous Method Ltrl+Fallp 


a YYindowsApplicationl - Microsoft Yisual Studio 


File i | Yi Project  Bulld Debug ÛOata Tools Window Lommunityp Hel 
کڪ ع‎ è‌ ıı ag * 
E ٤ | 
8 4 a ااا‎ trl, | ¥ | (Declarations) 
a EE Maal Ltrl+ 
E: 
۴ Delete Del 
.  FindandReplace ¢ ard .  FindandReplace ¢ ۴ 8 DM uick. Find O Ctrl+F 
laa lo... 4 Huck Replace O Ltrl+H 
Select ¿ll trl + [ê Find in Files O cin-sniter 
Insert File &z Tet... ^ê Replace In Files Ltrl+Shift+H 4 
Advanced 6 jê Find Symbol 5) Alt+F12 


Bookmarks 
البحت عن نض‎ -1 

٭- ايستبدذ ا لض 

3- البحت عن نص صع حرض النتاتج کقاتحد 


Outlining 


lntelllS EFzE 


4- استبداك نض صع حرض النتناتج كقاتحدة 
5- البحت عن حلت 
6- اضافةه تنسقفات النصضن 


Mest Method Ltrl+Fgln 
Previous Method Ltrl+Fgallp 


۷ 
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[View] 


تتكون من الازرار تلك التي تقوم باخفاء واظهار كل نوافذ واشرطة الفجول بيسك دوت نت 


E WYindowsApplicationl - Microsoft Yisual Studio 

File Edl | Yew | Project  Buld Debug Uala Tools Windom  Lormmunity 
I __@ | 
E] Designer @ Shift+F 7 

1 Server Explorer  Ltrl4كll+5‎ 

2 alution Explorer Ltrl+F 3 
LIbpect Browser F2 | 

Error List Ltr, Ltrl+E 4 
Properties WY lndany O F4 


ji Took O Cian 
Dther WIndows ۴ 


Toolbars @ ۴ 


Ol Full Screen Shifteûlt+E nter 
4 


Pending LheckInzs 


1- اظهار الجنصر الحصحدذتة بنحصط تحرير الكوت 
#- اهاز الجنصر الصحذد بنحط التصصيصم 

3- اظهار صستجرصضص الحصشروع 

4- اظهازر مستعجرصضص الذخطاء 

5- اظهار خحصائتص الحصشروع وصناصرة 

6- اطچاز صندذ وق الذدذوات 

7- اضاقة وحذف اشرطة الذتتصارات 


[Project] 
تتكون من الازرار التي تقوم باضافة وحذف العناصر من والى المشروع‎ 
وهذة القائمة نستطيع القيام ببعض اوامر ازرارها من النافذة‎ 
Explorer Solutions 


والخيار الاخير بالنافذة كما عرفنا هو لعرض نافذة خصائص المشروع 
والان سوف نستعرض اهم خصائص المشروع 
llتبوڀپ AppIiction‏ 
ومنه یتم تحدد نوع المشروع وبياناته 


۲۸ 
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e YindowsApplicationl - Microsoft Yisual Studio 


File Edl Wem | Project | Buld Debug Uala Formal Tools: Window Lon 


EI ® E 8 - ûdd Windows Forrn... @ 


+ |] # Il _ & 


. 7 Farm. FF HÎ Add User Lontral... 
ea dd Lormponert... 
Add Module... 

Ad Llasz... 


| 0|0 7 


Add Mew tern... Ltrl+S hitd, 
Add Existing Iter... © Ctrl+D 


E «clude Frarn Project 


Ê Show All Files 
Add Reference... 3 
| | 
Aid Web Reference... 


Wndonshpplicatlonl Propertes... 4 ۰ 


1- اضاقة تليق :حدذبد للصت رو2 
2- اضاتهة تطبيق حصحجحضر حبقا 

3- اضاقد ةاد صگونات اضافیه 
4- تنج نافذة خحصائص الصشروع 


 WindowsApplicationl = Microsoft Yisual Studio 
Fle Ed Yiew  Piaeel Bild Dekaiig Dal Tools Wmdow Lemmy Help 
ETE CIENT a TR 


WindowsApplication1"]’ Fouml.yb [Design] 7 Stal Page | 


ا 
Applizaion‏ 
Eb nam#: Fool namespace N‏ ق 
Compile WW mdowsA pplication WmdowsA pplication‏ 
Debug Apphcatlon type: leon ۰‏ 
Default loon] 1 3 Ec‏ | ا Wirda: Application O‏ | 
References‏ 
Starliap Fafî‏ 
Assembly Infomation... 4‏ يه 2 Resources Formî‏ 
Setlirigê Enable appheatlon framework‏ 
1- تحذيد لوغ الحمشروع | Signing Windows apphzalion fi amemcık. pr opesties‏ 
2- تكذيذ قورع بذاية المشروع 
3- تاديد ايقوتة للمشزوع Secuily” Enable XP visual styles‏ 
ا e‏ 
Make single instance application TE Th EE‏ ]|_|[ 
Publish‏ 
l#j Save My. Settings on Shutdown‏ 
ا Authenkication trode:‏ 
ی Windows‏ 
Shuidorm mode: ۰‏ 
۴ ا Wher stattup fair lOê?‏ 


۲۹ 
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eاCompi‏ التبویب 


تحديد شكل المعالجة ومنة يتم 


sS WindowsApplicatonl = Microsoft Visual Studio TEK 
FE ER View Pmectl Bild Ûebug DU loo Window Lommunly Hap 
ا ا ےو ار - 3 2 ۾ لرا‎ E" ۴ j E ر 8 گا‎ e ن و‎ 


ıı WYindowsApplicationl  Fom1.vb [Design]  Starl Page | 


کک 
PS Bi ouput Dati ™‏ 


Cornpile bin" Rielease" EFT 
Debug ۰ Advanced Lompile Dpliofê... 


e Option explicit: O  Oplion strict | Oplion compare: 3 
0n ي‎ | Off په‎ | Biray په‎ 


Resources 


Condition MHotilicallon 


Set irigs 
Implicit corryersiori | ote اپ‎ 
signing Lake brding; call could fail al run Hime Notre ي‎ 
Secu Implicit type: objec! assumed Note اپ‎ 
lse of vaniablë priot lo sesignimei Warming په‎ 
bii Funeion Operator wkhout runn Yale | Warring په‎ 
اقتا لکد !ا‎ ةتزةbا#‎ 7 Warming په‎ 
Irstarca wariabla ãccessas shared member ا‎ warming په‎ 
Recursive operalor or properly access 40 USS E په‎ 
Duplicate or overlapping catch blocks Wang يه ا‎ 
4 | 8 


مفعل فانة يلزمك بالاعلان عن كل المتغيرات بالمشروع ويفضل ذلك اذا كان هذا اÛخيlر Option Explicit‏ -1 


اذا كان هذا الخيار مفعل فانة يلزمك Opİi 0" s1‏ - 2 
نوع محدد من البيانات بيانات من نفس النوع اي لو كان لدينا المثال التالي اعطاء أي 


رمز. 
Dim i As Integer‏ 
Dim s As String‏ 
S "10"‏ 
i = s' This Fails.‏ 
s = "Hello"‏ 
i = s ' This Fails.‏ 


ولو كان الخيار غير مفعل فانة يقوم بتحويل البيانات 
المسندة الى النوع المراد اذا كانت مناسقة فقط مثلا 


رمز. 


Dim i As Integer 
Dim s As String 
S "10" 


i = s' This works. 
s = "Hello" 
i = s' This Fails. 
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ويفضل جعل هذا الخيار مفعل لجعل المعالجة اسرعوتحويل انواع البيانات باستخدام الدوال افضل و لجعل هذة الخيارات مفعلة 
لكل مشاريعك اذهب الى القائمة وامه۲ ومنها اخترم مامه وقم باختيار نامء ١ه‏ †ءهزهإم من قائمة العرض الشجري 
ومنۂ اختر وااںه]م5 ۷8B‏ وقم بتفعیل الخیاران وتم اضغط)م 


Mpitans 


=1: Environment 


Default propect setngz: 
laeneral 


. 


: Fonts and Lolars Uption Explicit: 
=1: Projects and Solutions 


Lption Strict: 
E YB Defaults 

#: Text Editor 

3:: WIndows Forms Designer 

#4 Device Tonls 


LIption Lompare: 


[_ | Shor all settings 


Binary or Textlڊ ها الخیار يحدي‎ Option compare 
وذلك لتحديد نمط معالجة النصوص اعتماد على البنري او على تحسس حالة الاحرف‎ 
ويفضل جعل خيار المعالجه بواسطة رهام لانه اسرع‎ 


التبويپ Resources‏ 
ومنة يتم تحديد ملفات تستخدم كمصادر 


E WindowsAp plication] - Microsofl Yisual Studio 


File Edl Ye  Fmjeel Bull Dela Ûala Taal Wmdo  Lommumiy Help 
ME N RE -T Ere" JER ESM SE 
WindowsApplicationl [| Fom1.vb [Design| 


Sart Fage 


Application | BAStinas = TÛ] Add Resource =| 


E ا‎ 
تك‎ E istrıg Fl... 
Lampils د اک ت‎ 
ا اتیگ‎ 5R | : 
Debug Mey Image 
Rê ا‎ Newe leon 
Ht New T ant File 
|۴ BSL CES 1 
Satlings 
Signing 
SEL 
Fublish 


۳١۹ 
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ومن ثم تستطيع التعامل مع الملفات التي اضفتها الى مشروعك كمصادر بكتابة الكود التالي 


رمز. 
اسم الريسورس الذي ترید.sمcں‌0‌sم‌R Ny.‏ 
فمثلا لو کان لدینا وم٥‏ uں‌موهمR‏ عبارة عن صورة واسم الصورةإم٤‏ 
واردنا عرض الصورة في ٥×‏ 6م ں]ء آم ما علينا سوى كتابة الاتي 


رمز. 


PictureBox.Image = My.Resources.Car 


التبویب ہوااbںم‏ 
ومنه يتم نشر المشروع اي تحویله لملٰف مںامS؟S‏ 


e WindowsApplicationê = Microsoft Yisual Studio IK) 
Fle EM View FPigject Build Debug Dals Ions Window  Cemmunkly Help 
RES LAL RL = 2 o lp u a Sa 


WindowsApplicalion?  Fom1.vb [Design] T Starl Page 


ا ړ 

PE Publeh Location - 

Compile Publishing Location [web site, fp | ,#er. or Tile palf 

Libiiğ 


Installation UAL [I different than above: ا‎ 
Relerarces ٠ يه‎ e 
Resources Install Mode and Settings 

(J The application i avalable online arly ___Êpplicalian Fes... 


Settings ce 
Signiğ 

LIpHat#s... 
SEL 


Majo: Mna Build _ Feveeorr 
1 1 1 | 0 
Automatically inetement rtevsîon wilh ach publish 


F۳ E roi List 


۳۲ 
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[Bulid] 


تتكون من الازرار تلك لتى تعمل على معالجة كلا من التطبيقات والمشاريع 


ft Yisual Studio 


| Uala Formal Tools 


LlEan Windows Ãpplizatlaorl 8 1 
Publish WIndows pplication Î O 


سس 
ا F۴‏ 


Ex 


Earm Î 


-١‏ يقوم بيناء صلضاتك و حفضخ التجدبلات 
آ- يقو م باعادذة بناء صلقانكت صلتف صلضف 
-٣‏ يفقوم بجذف الصلضات الصثقزة 

- يقوم بختج صعالج نر الصسردع 
لتحويلة لصلت: ۴1110ء5 


STITT OTOTOTTTOTOTOTOTIOTOTOTOTOTOTTOTOTOTTIOTTOT 


Debug] 


تحتوي هذة القائمة على ازرار الاوامر التى تقوم بعملية تنقيح وتصحيح 
الاخطاء البرمجية بكود البرامج 


nnIinqj ¬ Microsoft YIisual SltudIo 


Tools Windows LarmrmuarnIkty Help 


Locals LCtrl+Aalt+y, L 


Break ھےۓ¿ll‎ Ltrl+Break [ BEreakpolints Ltrl+Ãlt+E 


Stop Debuaalinga Ltrlrêlt+Break ڪ‎ uitpuit 
گر + اا + ا۲ا اا‎ 


1 1 1 ا‎ 
ll ll > 


L2ll Stack Ltrl+L 
Threads Ltrl+Alt+H 


1 


watch 

E#ceptlonz... Ltrl+Alt+E | A odulazs Ltrl+Alt+ Ll 
Script E #plorer 

Hew Breakpoint ۲ Processes Ctrl lt+Z 


٣ 
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Window 
یحتوی على قائمة فرعية بها الكثير من ادوات تتبع وتصحيح الاخطاء‎ 
Breakpoint Watch,þin 
Continue 


استئناف عملية التنقيح 


Stop Debugging 
ايقاف عملية التنقيح‎ 


Detach all 
فصل المنقح عن العمليات المرتبطة بة ولكن لا يقوم بانها تلك العمليات‎ 


Terminate all 
انها أي عملية مرتبطة بالمنقح‎ 


Restart 
ايقاف عملية التنقيح الحالية واعادة تشغيلها من البداية‎ 


Exceptions 
يقوم بفتح نافذة الاستثنائات حيث يمكننك تحيد نوع الخطاء الذي تريد ان يتعرف المنقح علية‎ 


New Breakpoint 
لاإضافة نقطة توقف جديدة‎ 


[Data] 


Yisual Studio 


Uata Formal Tools: Window Loaormmunity Help 


al Show Data Sources ShiftrAlt+D 1 ک‎ — a ا چ س‎ F3 
3 E FPreyiey Data... O 


Add Hew Data Source...‏ ل 


ta SOUGES 


1 1 
11 


E. 


1- لجرض ناتذثخ صصضذر البيانات التاتا صن خلذلها يحصكنك 
اضاتد قاعدة بياناات د احصكانيدة حصل الربط الحضوكب الحداولي 


2- استجراض بياناات حقوك ج بحداوك تاحدذة البيانات 


3 - كرض صجالج اضاتقة تاعحدذة بیانات 


Add Hew Data Sı 


هذة القائمة تستطيع من خلالها التعامل مع قواعد البيانات 


من اضافة وعرض وربط قواعد البيانات المختلفة 
Access ,Sql,Oracl‏ 


٤ 
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[Format] 


تحتوي على ازرار الاوامر التى تقوم بترتيب وتنظيم الادوات على الفورم 
واظن ان هذه القائمة لا تحتاج الى شرح فاسماء ازرارها تظهر اعمالها 


a YYindowsApplicationl - Microsoft ¥Yisual Studio 


File Edt Yew Project Build Debug Data 
ARB E - R@ M 3 اا‎ 
„7 Form1.¥b [Design] Form. 


Formal | Tools 


nda Lormmunity Help 
کا ي ۴ اا‎ = 


. agg r rth 


Harlzontal Spacing F د‎ || Height 


Form Î YWerlical Spach F 


Lenter In Forrn ۴ 
rder ۴ 


Lack Controls 


اذا ارذت تجحجيح عدت صن الذذوات لتكوب حسب 
شگل ادات حصجينة ققح بتحدذيدذ حصية الذذوات الذكي 
تريد تجصها وذلك بضخط على الزر أ٣)]‏ صع النقر بالصاودس 
وود بتحديد الذذاة الصرات التحجيح عل ابسايسها وانقر علبها 
بالصاوس حتذى يكو التحدذيد عليها باللوت الذابيض تم صن القاتده 
Both jië| laiaڊ ake Same Size jiîz| Format‏ 


[Tools] 


تحتوي هذة القائمة على الاوامر التى لا يتلائم وضعها في أي قائمة اخري 
وهي التي تستطيع تغيير بيئه تطوير الفجول نفسها 


Taols  YYnmdoy LUommunity Help 
ûttach to Process... Ctrleilt+F 


ا ا ی کے 2 ل 


ا1 


Lonnect lo Dewice... 
Lonnect lo Database... 


Lonnect to Server... 


Lode Snippets Manager... Ltrl+E, Ctrl+B 
Lhoaosze Toolbox lterns... 
Add-in Manager... 
Macros 


lIparade Yisual Basic B Lode... 


External Toanls... 
Device Emulator Manager... 
Irmport and E#port Settings... 
Lustaormize... 


Upktionz... 
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[ Attach To Process 
Attach يقوم بفتح نافدة ربط المنقح مع عمليه تنفد حاليا اختر اي عملیه نم اضخ¡ڊ‎ 


Connect to Device 
يتیح لك هذا الخيار الاتصال مع اداة او جهاز مثل الهاتف الكفي او الهواتف الذكيه‎ 
Connect to Pocket PC or Smartphone devices or emulators 
وذلك لاختبار البرنامج الذي تصممة من اجلها‎ 


Connect to Database 
يقوم هذا الخيار بفتح نافذة الاتصال مع قاعدة البيانات ومعرفة القواعد المرتبطة‎ 
مسبقا مع السرفر الخاص بربط البيانات‎ 


Code Snippets Manager 
يقوم بفتح نافذة مدير مقاطع الاكواد لاضافة او ازالة المقاطع وكيفية‎ 
استخدام هذة المقاطع من الاكواد الجاهزة يمنكنك الضغط بالزر الايمن في شاشة‎ 
Insert Snippetرlيتخا الکود ڌم‎ 
وستعرض لك الاكواد مقسمة بمجلدات حسب الفئة قم باختيار أي مجلد تريد‎ 
ثم ستعرض اسماء لاكواد الموجود بالمجلد قم بالضغط على اسم الكود الذي تريد‎ 
وسيقوم الفجول بيسك باضافتة مباشرتاً‎ 


Choose Toolbox Items 
۲٥0۱8 يقوم هذا الخيار بفتح نافدة اختیار وحذف الادوات من×0‎ 
فالادوات المضافة تلقائيا بعد تثبيت الفجول ستديو دوت نت ليست كل الادوات المتاح‎ 
استخدامها بل يوجد هنالك الكثير من الادوات التي يمكن اضافتها‎ 


Macros 
يحتوي على قائمة فرعية تستطيع من خلالها انشا و تعديل او تنفيذ ميكروا‎ 


External Tools 
آ٣٥م۵اs‎ ٥ں یقوم باضافہ او حدف زر من ال‎ 
متلا تستطيع ان تضيف زر يشغل أي برنامج من داخل الفجول بيسك‎ 


Device Emulation Manager 
تقوم بفتح نافذة ادارة الاجهزة تشغيلها او اغلاقها والاتصال بها‎ 


Import/Export Settings 
|2 يقوم هذا الخيار بفتح معالج حفظ او استعادة اعدادات بيئة التطويرع‎ 


Customize 
يقوم هذا الزر بفتح نافذة ٥İہه]وں التي تستطيع من خلالها تعديل ازرار القوائم‎ 
من اضافة وحذف وتعديل مظهر القوائم من اضافة القوائم الفرعية‎ 
ويمكنك اضافة الازرار بواسطة السحب والافلات في اي قائمة تريد‎ 


Options 
يقوم بفتح نافذة تستطيع من خلالها تحديد الخيارات الخاصة ببيئة التطوي‎ 


۳٦ 
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[ Window ] 


تحتوي هذة القائمة على الاوامر التى تتحكم في نوافذ الفجول بسيك دوت نت 


Loamrnunity 


Help 


Mey Horizontal I ab Group 
Mewy Wertical Tab Group 
Llose ږAll‎ Documents 


Reset Window Layout 


1 Formi.Yb [Deslan] 
û Forml.yb 
3 Start Faqe 
WIndows... 


Dockable, Floating, Tabbed Document 
تتعامل مع النوافذ الثانوية مثل‎ 
Toolbox, Solution Explorer, 
بتغيير طريقة اظهار النافذة أي تكون ظاهرة بشكل عائم او بشكل ثابت‎ 
او النقر المزدوج على شريط عنوان النافذ لجعلها عائمة او تكرار النقر لتثبيتها‎ 
والان قم بالنقر المزدوج على شريط العنوان لاي نافذة ثانوية‎ 
كي تكون بشكل عائم ثم بواسطة الضغط المستمر بالماوس‎ 
على شريط العنوان وسحب النافذة سوف تظهر لك‎ 
مقابض في شاشة الفجول تستطيع بواسطة هذة المقابض‎ 
تثبيت النافذة في أي مکان تربد‎ 


Auto Hide 
تقوم بخفاء بخفاء تلقائي للنافذة الثانوية وتظهر عند مرور الماوس عليها‎ 
Hide 
ز٥س يقوم هذا الخيار باغلاق النافذة الثانوية و نطب اظهارها مره انيه من القائمة‎ 
او من خلال الضغط على اختصار اظهارها من شريط الاختصارات‎ 
Auto Hide AII 
يقوم باخفاء كل النوافذ الثانوية الظاهرة‎ 


۳۷ 
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New Horizontal Tab Group 
يقوم هذا الخيار بعرض اكثر من محرر في وقت واحد على الشكل الافقي‎ 
أي اذا كانت تعمل على محررالتصميم للمشروع وتريد ايضا العمل على محرر الكود‎ 
قم بالضغط على هذا الخيار وسيكون الشكل كما هو موضح بالصورة‎ 


Te YY indowsApplicationl - Microsoft Yisual Studio 
File Edl Yew Project  Buld Debug Lata Formal Tools Windom Lommunily Help 


3 ± ۾ ل م | ت م 5 د 4 ل ٣ك‏ تاه لن 
ف 

) yb4Aarab 
۷ 


E Class Form1l و ن‎ 
Private Sub Forml Load(EyYal sender As System. Vb ject, _ 
EyYal E A3 System. EvEeEnNnTAFS23] Handles HyEBa3se . Load 3 

Hs{Box ( "YTEIFLELE THE BEST WEB SITE") ف‎ 
End Sub 
ENI LISS 
اب‎ 


| 
| 


New Vertical Tab Group 


يقوم هذا الخيار بعرض اكثر من محرر في وقت واحد على الشكل العموديأي اذا كانت تعمل على محررالتصميم للمشروع وتريد 
ايضا العمل على محرر الكود قوم بالضغط على هذا الخيار وسيكون الشكل كما هو موضح بالصورة 


۳۸ 
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 WindowsApplicationl - Microsoft Yısual Studio 


Filê Edl Yiw Pijtl Bid Dêëbiiğ DÛãalê Toöölê Window  LComîmianiy Hil 


ET ET TOC EE ECICIEOTT CEE 
+ Foml.vb [Design]" Start Page | ¥ xX  Forml.vb"| 

I (Declarations)‏ به SS | J (General)‏ چصھصھصڪ 

i 5 vb4arab 0 | E Fublic Class Form1 


PFiwatê Sib Form1 Löad(Byval saender | 

Aa Syatem.Ubject, ByYal e is System. EveEntAr‏ آ 
HsgBox | "VTEOSIALRAE THE BEST UEB SITE"]‏ 

٣ Enda 3uۈb‎ 

- Fond LJIaz=s 


Close All Documents 
يقوم هذا الزر باغلاق كافة المحررات المفتوحة‎ 


Reset Window Layout 
يقوم باعادة النافذة للوضع الافتراضي لها‎ 


Windows 
يقوم بفتح نافدة تستطيع منها تحديدة او اغلاق اي محرر مفتوح‎ 


[Community] 


i_i Unity 
اه‎ Ask a Question 
heck Question Status 
wR Send Feedback 
Developer Lenker 
_odezone LZomrnuniky 
Partner Products Latalag 


_ommunity Search 


تحتوي على الاوامر التى تساعدك في الارتباط مع مجتمع البرمجة بالفجول بيسك 


۳۹ 
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بحيث يمكنك ان تسئل وتقوم بالبحث عن اجابة او امثلة وهذة الاوامر مرتبطة‎ 
MSDN Community Center ةرlيj بصفحات میکروسوفت كما كنك‎ 
من خلال هذا الرابط‎ 
http ://msdn2.microsoft.com/en-us/aa497440.aspX 


[Help] 


@Î How Do I trl+F1 
A, Search ctrl+Alt+E3 
df Contents Ltrl+Alt+F1 
Index trl+Alt+FZ 
E3 Help FaYorites wErl+Alt+F 
@| Dynamic Help ctrl+alt+F4 
| Index Results Shift+Alt+F2 
_ustomer Feedback Options... 
Register Product, 
heck For Ipdates 
yê Technical Support | 


About Microsoft Yisual SEJdio | 


تحتوي على الاوامر المالوفة الخاصة بالمساعدة والاتصال بموقع الشركة والتعرف على كيفية استخدام اللغة وخيار العثور على 
التحديثات اللازمة للبرنامج 
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o0 الادوات فى الفيجوال بيسك دوت نت‎ 
اشكال رسومية ولكل اداة عملها الخاص تاخذ هي عبارة عن عناصر برمجية لها مهام معينة : الادوات‎ 
* الادوات الى صنفين تصنف‎ : 
Control : 


البرنامج ويقوم بتادية مهمة معينة مثل تصميم معين ويوضع على الفورم اثنا ء العنصر البرمجي الذي يأخذ شكل رسومي وهو 
خصائص ووظائف تميزة عن غير Button , Textbox , Label Jİ Control‏ 


Component : 

: فیما عدا اه٥‏ وهو شبیه بال 

يظهر في وقت التنفيذ أي وقت الاستعمال لا 

به أسفل الفورم على شكل ايقونه يظهر اتنا تصميم البرنامج على شريط خاص 

Open FileDial9‏ او وقت التنفيذ مثل uںممم‏ اثناء التصميم مثل ولكن بالرغم من ذلك يمكن ان يظهر على الفورم 
: التعامل مع الادوات* 


فتقوم باختصار الكثير من الاكواد الصعبةوالطويلةولكل اداة من ادوات تصميمة برنامج بقدر كبير الادوات تساعد المبرمج اثناء 
ومهمة معينة وتقومكل اداة بعمل مختلف عن الاداة الاخرى الفجول بيسك دوت نت غرض معين 


i Ê > Ë E 


3 


E 
r 
8 
1: 
ج‎ 
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انشاء الإدوات:‎ 


*يمكنك اضافة اى اداة الى برنامجك باحدى هذة الطرق : النقر المزدوج على الاداة المراد اضافتهالسحب والافلات 
باستخدام الماوسالنقر نقرة واحدة على الاداة المراد اضافتها وثمالنقر نقرة واحدة على الفورم وسيتم اضافتها 


*ولكن لو اردنا انشاء مجموعة كبيرة من الادواة كعمل برنامج حاسبة بة ازرار عديدة مثلافاءن الطرق السابقة 
لاضافة الازرار ستكون متعبة قليلافما هو الحل ياتري في رايك ؟الحل هو الضغط المتواصل على مفتاح ا)٥‏ ثم النقر 
نقرة واحدة باستخدام الماوس على الاداة التى تريد اضافه عددأ منها ثم النقر على الفورم ستلاحظ في كل مرة تقوم 
بها بالنقر على الفورم اضافة الاداة مرة جديدة وباسم جديدوعندما تريد الانتهاء من اضافة الاداة فما عليك سوىايقاف 
الضغط على مفتاح ٥]‏ اوالضغط على ايقونة موشر الماوس التي في اعلي الادوات. 

تجميع الأدوات داخل حاوية. 

هنالك أدوات عملها الأساسى هو احتوى ادوات اخرى بداخلها مثل 

TabControl, GroupBox, Panel, 


وباستخدامها تستطيع تجميع عدد من الادوات في حاوية واحدة لغرض نقل وتحريك او اخفاء واظهار تلك الاإدوات او 
لاغاض اخری. المهم في لامر اننا باستخدام حاويات الادوات نستطيع ان نتعامل مع مجموعةمن الادوات ككتلة واحدة 


هنالك عدة طرق لتضع الادوات داخل حاوية container‏ وذلك بسحب الاداة الموجود على الفورم الى داخل 
ontainerءاو‏ بتحديد ال م« iهامهء‏ الذي قمت باضافتة مسبقا الى الفورمثم و من قائمة الادوات تقوم بالنقر 
المزدوج على الاداة التىتريد ان تضيفها الى ۲ه اههء وستضاف بداخله مباشرتاً وليس على الفورم او بواسطة 
السحب والافلات من قائمة الإدوات الى داخل ال. ۲مم iها"هء‏ او بواسطة القص واللصق من على الفورم الى داخل ال 
container .‏ 


*انشاء الادوات في وقت التنفیذ: مہ١٣ Ru‏ 


غالبا نقوم بانشاء الادوات على الفورم في وقت تصميم البرنامج عن طريق اضافتها من قائمة× ٣٥١۱8٥‏ ولكن 
وبالرغم من ذلك فاننا ي بعص الاحيان قد نحتاج لانشاء الادوات کی وقت تنفيذالبرنامج Run Time‏ اي انشاء الدوات 
والاحداث الخاصة بها عن طريق الكود. 


ولكن قد نتسائل ما الدافع الذي يجعلنا ننشئ الادوات بواسطة 
الكود طالما اننا نستطيع انشائها في وقت تصميم البرنامج ؟ 


الجواب انك في بعض الاحيان قد تحتاج لعمل برنامج يملك واجهات مختلفة يخدم مستخدمين مختلفين .المستخدمين 
مختلفين في مهاراتهم او يحتاجون لادوات مختلفة تبعا لاختلاف اعمالهم ومتطلباتهم .او انك لا تعلم ماذا سيتطلب 
برنامجك من ادوات لعرض او ادخال البيانات لان ذلك متوقف على حاجيات المستخدم للبرنامج . أي انك سوف تحتاج 
الى انشاء ادوات في وقت التنفيذ. مآ مں# الان سوف نتعرف على كيفية انشاء الادوات وقت التنفيذ: مصأ u٠‏ 


انظر الى هذا الكود 


1- Dim IbIHi As New Label 
2- IbIHi.SetBounds (50, 50, 70,70) 


3- IbIHi.Text="Hello World" 
4- Me.Controls.Add (IbIHi) 


بهذا الكود نستطيع انشاء امطج ا على الفورم في وقت تنفيذ البرنامج وألان نأتي لشرح الكود في السطر الاول قمنا بالاعلان 
عن المتغير ١1۸ط|‏ على انة من النوع . امطج] في السطر الثاني قمنا بتحديد احداثيات ۳١ط‏ على الفورم بواسطة الخاصية 

oun ds .‏ 1BهSفي‏ السطر الثالث قمنا بتغيير الخاصية ٤×ه]‏ ليكون الاسم الظاهر لل امطج اهو . ١اه‏ ه|اام١‏ ثم في السطر 
الرابع والاخير قمنا باضافة ١1۳ط|‏ الى الادوات التابعة للفورم الحالي بواسطة الخاصيه ه۸0 المترفعة من الخاصية ءاهإ†"هC٥‏ 
التابعة للفورم . ولكن لم نحتاج لعمل حدث تابع للاداة امطج] لاننا في الاغلب نستخدمها لعرض معلومات على الفورم ولكن 
هنالك ادوات اخری مثل ٥٤ں‏ لا نستطيع التعامل معها الى بواسطة الإحداث التابعة لها كحدث الضغط عليها مثلا . والان 
سوف نتعرف على كيفية انشاء اداة في وقت تنفيذ البرنامج مع انشاء احداث تابعة لها واولا يجب ان نعرف اننا اذا اردنا 
الاعلان عن متغير على انة من نوع اداة ما بيجب ان يكون الاعلان مبتدا بالكلمة المحجوزة ی٣٥۷‏ ٤ط]W‏ أي اننا نصرح عن 
متغير من نوع اداة وله احداثة التابعة له مثلا نكتب 


٤۲ 
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Dim WithEvents btnHi As New Button 
هنا اعلنا عن المتغیر ۴۸ط ان من النوع ٥٥]]ںع واذا اردنا الوصول الی احداثة کلما علینا هوالدخول الى شاشة الکود تم‎ 
ومن قائمة سرد العناصر الموجودة بالفورم الحالي م٠۳ه. ءءهاع ثم تحديد الحدث المراد من قائمة سرد احداث العناصر‎ 
الى الصورة التالية‎ رظناNethod‎ Name 


تچ و بے : 1 : r EE‏ 

e YYindowsApplicationl - Mıcrosof Yısual SIUAIO CPR 
File Edt Yew Propectl Buld Debug Uala Iools Windom Lomrmunity Help 
ك و فة‎ 


FrormievE Fem el Mead 


î Fomî 
| [General] 


| Formîl 


WithEZENES prtnHi A3 Button 


End LIas3s3 


الان قم بفتح مشروع جديد وقم في منطقة التصريحات العامة بكتابة هذا التصريح 


رمز. 
Dim WithEvents btnHi As Button‏ 


ثم قم قائمة سرد العناصر مه" ءوه|ع باختيار العنصر ١٨ط‏ كما توضح الصورة السابقة تم قم باختيار الحدث الذي تريدة 
لهذا العنصر من قائمة سرد احداث العنصر انظر الصورة التالية 


4۳ 


[Declarations] 
F Auto IlzeLhanged 
4F BackLolor.hanged 


+ BackarnundlmageLharged 
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4 Enter 
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File Edit Frajecet  Buıld Debug 

ق 2 ق فت 

Form +b | 
aw btnHi 

FH Public LlaS3 Forrml 


اا 


EE [Design] 


WITthEZEnNTS prtrnHi1 A3 But! 


End lass 


أي اننا بمجرد الاعلان عن متغير انة من نوع اداة فان الفجول يقوم بانشاء احداث لذلك المتغير ويتاعمل معة وكانة عنصر 
موجود على الفورم . ونهاية لفهم ما سبق نقوم بهذا المثال قم بانشاء مشروع جديد قم بكتابة هذا الكود في منطة التصريحات 


العامة 


N ith Events btnHi As Button‏ ثم قم باضافة But‏ على الفورم وقم بالنقر المزدوج علية لتدخل الى شاشة الكود في 


الحدث )اا _۸1 ٥ں‏ قم بكتابة الكود التالي 


btnHi = New Button 
btnHi.SetBounds(96, 50, 75, 23) 


btnHi. Text = "Say Hi" 
Me.Controls. Add(btnHi) 


ثم قم بعمل حدث »مزاع للعنصر ٨1ط‏ كما تعلما واكتب بداخلة 


رمز. 


MessageBox.Show(“Hi Man”) 


٤ 
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ره اذا قمت‎ ۳٣١ والان شغل البرنامج وقم بالضغط علی الزر ۸1٥٤]ںB ستلاحظ ظھور ٥٥t†ں‌B جديد على الفور لة الاسم‎ 
1i بالضغط علية سوف تظهر لك رسالة مكتوب بهاہ ج“‎ 


تكلمنا في الدرس السابق عن الادوات وتعلمنا كيفية انشائها على الفورم في وقت التصميم او في تنفيذ البرنامج ولكن بقي 
ملاحظة تخص انشاء الادوات في وقت التنفيذ وهي كيفية حذف اداة ما في وقت التنفيذ ثم سننتقل بعدها الى خصائص الادوات. 


حذف الادوات وقت التنفيذ: 


مثلا لو کان لدینا ہہاں‌B‏ اسميناة ٨۳ط‏ ونريد حذفة من على الفورم في وقت تنفيذ البرنامج كلما علينا هو كتابة الكود التالي 
في زر امر حذف ذلك ال ٥اا‏ ں‌B‏ 


Me.Controls.Remove(btnHi) 
btnHi = Nothing 


سيقوم ذلك الكود بحذف الزر in۳‏ من على فورم البرنامج حتى ولو تم انشاء ذلك إل tt‏ في وقت تصميم البرنامج أو 
في وقت التنفيذ ولكن حذف أداة من على فورم البرنامج إثناء تشغيله لا يعني انه تم حذف أحداث تلك الاداة. 


خصائص الادوات وكيفية التعامل معها: 


الخاصية : هي قيمة او بعض القيم التابعة لاداة التحكم والتى تتحكم في عمل او مظهر الاداة . مثلا اداة التحكم >م18×ه] تمتلك 
الخاصية Name‏ وهي التی تتحکم کی اسم الاداة البرمجى الذي بستخدمة المبرمج ج اثناء كتابة البرنامج وكذلك الخاصية 1٥×‏ 


وهذة الخاصية هي التى تتحكم کی الكتابة التي ستظهر ×0 ٣٥×18‏ وتوجد ايضاء الخاصية Back Color‏ وهي التى تتحكم في 
لون الخلفية وهكذا. 


لكل اداة خصائص عديدة وتتشابة معظم الادواة في الكثير من خصائصها ولكن هنالك خصائص لا توجد الا في نوع محدد من 
الادوات مثلا الاداة ImageList‏ تمتلك الخاصية Images‏ التى تستطیع باستخدامها من اختيار العدد الذي تريد من الصور التى 
سوف تخزنها هذة الاداة لاستخدامها کایقونات مثلا مع ادوات اخری مثل استخامها مع اداه العرضص الشجري. TreeView‏ 


| لخصائص في وقت ا ۸ لتصميم: 


لتعديل خصائص أي اداة من ادوات التحكم في وقت تصميم برنامجك يجب اولا ان تة تقوم بفتح نافذة الخصائص وتستطيع فتحها 
من القائمة سە¡ واختیار sسە0لہ¡W es‏ ممه او بالضغط علی المفتاح ۴۸ من ن لوحة المفاتيح . بعد فتح نافذة الخصائص 
يبقى ان نحدد الاداة التى نريد تعديل خصائصها وذلك يتم بطريقتين الاولى باختيار اسم الاداة من اعلى نافذة الخصائص او 
بالنقرعليها نقرة واحدة باستخدام الماوس فتظهر لنا جميع خصائص تلك الاداة في نافذة الخصائص بعدها نقوم 

بالنقر بالماوس امام اسم الخاصية المراد تغييرها وكتابة او اختيار القيمة الجديدة لها. 
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Tin 
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هنالك انواع كثيرة للخصائص فهنالك الخصائص المركبة من اكثر من قيمة والخصائص المحصورة بين قيم محددة وثابتة كذلك 
هنالك الخصائص المجمعة كمجموعة وسوف نستعرض كل نوع من انواع الخصائص على حدة كي نفهم كيفية التعامل معها. 


-1الخصائصضص المركبة. 


بعض من الخصائص تمتلك قيم مركبة مثلا الخاصية ٥١‏ ناء ه] تتكون من الحداثيان ۷ هه × والخاصية ماك تتكون من 
القیمتين وم width ad‏ والخاصیة م۴ متلا تتکون من القیم وsومہ‏ لاط ,مآs‏ ,meھہ 1s‏ ەfوغیرھا‏ من خصائص 
الخطوط أي هنالك خصائص تتكون من اكثر من قيمة ونلاحظ في الصورة السابقة ان هنالك خصائص امامها علامة الزائد ( + 
) تلك هى الخصائص المركبة فلوا قمت بالنقر على هذة العلامة سوف تظهر لك قيم هذة الخاصية. 


-2الخصائص المحصورة: 


هي الخصائص التى تكون قيمها محصورة ومحددة وتكون قيمها على شكل قائمة سرد بها القيم الممكن اعطائها للخاصيه 
ومثال على هذة الخصائص الخاصية ماطاو۷ فهدة الخاصیھ تمتلك احدی القیمتین ٥ا۴‏ ۵ھ مں٣۲‏ ولا يمكنك اعطائھا قیم 
اخرى الا اذا كانت القيمالاخرى مساوية للقيم الحالية مثلا القيمة 1- =مں٣۲‏ والقيمة. 0 =مءاج۴ 


هنالك خصائص تتكون قيمها من مجموعة من القيم او العناصر مثلا أداة التحكم ×160ءاا تمتلكالخاصية و !]٥‏ التى تتكون 
قيمتها من مجموعة من العناصر تلك التى تقوم اداة >16ءآا بعرضعااو مثل الخاصية اأءأاموهص| فيمها تتكون من مجموعة 
من الصور يتم عرضها بأدوات أخرىكذلك هنالك خصائص قيمها تتطلب وجود أداة أخرى فمثلا لعمل صور باعلى عناصر الاداة 
اabContr0ايجب‏ ان توجد الاداة اوا اموه"| واعطاء الخاصية وموهم| التابعة لها مجموعة من الصور كي نقوم بعرضعا 
كايقونات في عناوین . 1ا٥۲أ ٣‏ طه۲ وسوف نقوم بمتال لعمل ذلك. 


٤٦ 


مثال وضع الصور ڊgliaڍjù: TabControl‏ 
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قم بفتح مشروع جديد بالفجول بيسك دوت نت ثم قم باضافة هذة الادوات الى فورم البرنامج الاداة اها†أ٣‏ طج٣‏ وعدل 
الخاصية ٠ه"‏ لتكون م×٤طه۲‏ والاداةوiاموa"|‏ وعدل الخاصیۂ ٥ھ‏ لتکون م×٤طة٣ءاومص!‏ تم قم بالنقر نقرة واحدة 
Eأأ”lد|Exp5 ImglstT ab‏ فتظهر لك خصائصها بنافذة الخصائص ومنها قم بالنقرامام الخاصيه Images‏ وستظهر لك نافذة 


محرر اضافة الصور التابع ألاداة 


Images Collection Editor 


eErmberz: 
Haz= LCOROMOIICD 
ES LLDRAIYE.ICDU 


ولو تلاحظ الصورة فانة يوجد صورتين تم اضافتهما مسبقا فقم انت الانباختيار صورتين بواسطة الزر لهه ثم بعد ذلك اضغط 
)0 عندها سيغلق محرراضافة الصور وستعود الى وضع تصميم البرنامج الان قم بتحديد الاداةم×٤طه]‏ لتظهر خصائصها 
بنافذة الخصائص والان قم بالنقر امام الخاصية اوا اموهم| التابعة للاداة م×عطه۲ وقم باختيار !ڼٺداImgIstTabExp‏ 
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والان قم بالنقر امام الخاصية موه ٥‏ طه۲ التابعة للاداة م×عاطه٣‏ وستظهر لك نافذة تعديل واضافة التاب (وطه٣)‏ وباقي 
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الشرح انظر للصورة 
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Imagelndex 


ويجب ان تعرف ان الصفحات او ما يعرف بالتاب (sطه٣)‏ المكونة للاداة ٥ه‏ تعتبر ادوات داخلية لها خصانصها المرتكزة 
على خصائص الاداة الرئيسية وهي اهإ"ه ٤‏ طه ويمكنك اضافه العدد الذي تريد من التاب من خلال الزر هل۸ الموجود 
اسفل نافذة محرر اضافة وتعديل التاب 
وفي النهاية سوف يظهر البرنامج بهذا الشكل 


TabPagez‏ ن 


Hl Form-TabExmpl 


٤ a TabPagel i: 


4۸ 


Prog : Mohamed Youssef 
مصفوفة الادوات‎ 


في الفيجوال بيسك ٦‏ كانت هنالك ميزة جميلة ومفيدة وهي المقدرة على عمل مصفوفة من الادواتومصفوفة الادوات عبارة 
عن مصفوفة من اداة معينة بحيث ّ بحيث تتشارك نفس الاحداث وايضا لھا نفس الاسم ونستطیع التمییز بینها بواسطة ٥×‏ لہا الممیز 


وايضا هو الحال في 2005 ۷6.٤۲‏ فان هذہ الميزة باقية ولكن مع بعض الاختلاف في كيفية انشاء مصفوفة الادوات عن 
الفيجوال بيسك .١‏ 


ماهي الفائدة من مصفوفة الادوات وما الفائدة منها? سوال قد يدور في عقول الكثير وساجيب علية بالمثال التالي 


E O OER ONE PERT GO EOE 
الحاسبة فلو دخلنا الى شاشة الكود ماذا سنشاهد منظر غير جيد من تراكم الكود وعدم تنظيمة ولكن ما رائيك لو اختصرت كل‎ 
احداث الازرار بحدث واحد فقط هذا شئ غاية في الروعة ويقلل الجهد ويزيد التنظيم هذا صحيح.‎ 


والان لنقوم بعمل المثال عمليا. 

قم باضافة B J0۸‏ الی فورم وقم بتسمينة bin Num‏ تم قم بانشاء حدث لة بالضغط علية دبل كلك بعد انشاء الحدث ادخل 
الى شاشة التصميم وقوم بنسخ الزر ولصقة ٩-۰‏ اي عشرة ة ازرار ثم قم بالضغط دبل كليك على اي زر من الازرار ستدخل 
بذلك الى شاشة الكود وستلاحظ اضافة اسم ذلك الزر الى جانب حدث الزر ٣‏ ںل۸ہط والان قم بالضغط دبل كلك على کل 
الازرار كي يضاف اسمائهن للحدث والان كيف سنميز كل زر نظغط علية اولا قم باعادة تغيير الخاصية 

)× للازرار لتكون الاعداد من ٩-٠‏ وقم باضافة ×هط×ه] الى الفور واجعل اسمة سء >i‏ ثم قم بكتابة هذا الكود في الحدث 
btnNum.Click‏ 


PH ۴ الرمز:‎ 
Dim MyButton As Button = DirectCast(sender, Button) 
txtview.Text = txtview.Text & MyButton. Text 


Anchor and Dock jlتيصاخlنا‎ 


الخاصيتان )ء00 لہج ۲مطعمA‏ تعملان جعل الاداة تقوم تلقائيا بتغيير حجمها وموضعها تبعأً لحجم الفورم الموضوعة علية 
الخاصية هاعم تحدد أي حد من حدود الاداة يجب ان يبقى ثابتا واي حد يجب ان يزيد عن حجمة الحالي تبعا لحجم الفورم 
الموضوعة علية 


ولا توجد الخاصية مہ۸ الا مع الادوات التى تظهر على الفورم في وقت التنفیذ مل واا , ٦٥×18 ٥>‏ , ٣٥اا8u‏ وتملك هذة 
الادوات اربع حدود هي اوا ,اا ,mهاامB‏ ,م٥۲‏ و تحسب قيمة هذة الحدود بالنسبة للفورم 
بالباسيكل (ام×ام) والقيمة الافتراضية لهذة الخاصية هي اما ,مه1 


و في الاصدار السادس من الفيجوال بيسك لو اردنا مثلا عمل محرر نصوص مثل dهمهه"‏ فاننا سوف نحتاج لكتابة كود يقوم 
على تغيير حجم ×0 ٠٠×18‏ المستخدم للكتابة تبعا لحجم الفورم الموضوع علية كي يتلائم شكل البرنامج وكذلك الحال لو اردنا 


ولكن مع الفيجوال بيسك e O O RE TREE TOE ۲ ۰ ٠١‏ 
بالشكل الذي نريد ان تكون علية عند تغيير حجم الفورم ثم نقوم بتحديد حدود الاداة التى نريدها ان تتغير تلقائيا تبعا لتغير حجم 
الفورم 


سنقوم بعمل مثال لتتضح الفكرة قم بانشاء مشروع جديد بالفيجوال بيسك ٠٠٠٠١‏ ثم قم باضافة الاداة × ٠٠×18‏ الى الفورم 


وتغيير الخاصية Multiline‏ لتصبح مں إ۲ وهي الخاصية التى تعمل على ظهور اكثر من سطر بالاداة بوقت واحد وستظهر بعدها 
مقابض تغيير حجم الاداة ثم اجعل حجم الاداه على الفورم كما بالصورة 


۹ 
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HE Forml 


ثم نقوم بتغيير قيمة الخاصية ما۸ بحيث نقوم بتحديد جميع حدود الاداة >0 ۲٠١×168‏ 
وذلك بالنقر بالماوس على الحد الذي نريد اختيارة انظر الصورة 


Properties I F*K 


TextBoxl System. windows. Forms. TexlBo# ” 


تا ج 


ا 

[DataBindings] اش‎ 
[Hare] TextBox] 
AcceptsReturn False 2 
Accepts T ab False 


ûAccesslbleDescriptal 
ûccesslbleH arme 


ûccezszlbleR ole Default 
Allow Drap False 
Top. Left ېه‎ 


BackLolar 


Anchor 


Defines the edges of lhe contalner lo which ã 
certaln cortrol ls bound. Wher ã control I& ãN... 


بعد ان نقوم بتحديد جميع حدود الاداة الاربع نقوم الان بتشغيل البرنامج 
ونعمل على تغيير حجم الفورم ستلاحظ ان الاداة ٠٠×»80×‏ يتغير حجمها تبعا لتغير حجم الفورموالان لنقم بمثال اخر قم باضافة 
8tn‏ الى الفورم وقم بوضعه الزاويه العليا من الجهه اليمنى على الفورم 


Prog : Mohamed Youssef 
Form] 


__ Bukttonl 


ثم قم بجعل قيمة الخاصية مء" تساوي ع0× 


أي قم بالغاء تحديد كل حدود الاداة وقم بتشغيل البرنامج وتغيير حجم الفورم ستلاحظ ان الاداة تعمد الى الانتقال الى قرب 
منتصف الفورم والان قم بایقاف البرنامج وتغییر الخاصیۂ مہ۸ لل ٥٥ں‏ لتكون قيمتها تساوي ۸وا ,م٠٠‏ وهو اننا 
حدد ثم قم بتشغيل البرنامج وتغيير حجم الفورم ستلاحظ ثبات ال ١٥ں‏ في الزاوية العليا من الجهة اليمنى مهما تغير حجم 
الفورم وذلك لاننا قمنا بتثبیت حدود الاداۃ ۸۲٣وا‏ ,م٥٣‏ بواسطة الخاصیة فکلما قمنا بتغییر حجم الفورم فان ال ٥٥ں‏ یعمد الى 
الانتقال الى تلك الجهة المثبتة حدودة عليها كذلك يمكننا تغيير موضع الادوات في وقت تنفيذ البرنامج مثلا قم باضافة ہ ٥٤ں‏ 
الى الفورم وقم بوضعة باي مكان ثم قم باضافة هذا الكود الى الحدثلھها_۳١٥۴‏ 


رمز. 


Button1.Location = New Point(Me.ClientRectangle.Width -Button1.Width, Me.ClientRectangle.Height - 
Button1.Height) 
Button1.Anchor = AnchorStyles.Bottom Or AnchorStyles.Right 


والان لنقم بمثال اخير قم باضاف ثلاثة ٠×8‏ على الفورم تم قم بجعل شكلها على الفورم كما ما توضح الصورة 


Eorrrı | 


°۹ 
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ثم قم بتغيير الخاصية هم٣٥٣۸‏ للاول لتكون قيمتها مه۲ والقيمة للثاني ٠ه"‏ والقيمة للثالث 60)0٥ n‏ 
تم قم بن بتشغيل البرنامج وتغيير حجم الفورم وستلاحظ ان الادوات يتلائم موضعها على الفورم مع تغيير حجمه 


الخاصية )ه0 


تقوم بتثبت موضع الاداة في احد جوانب الفورم او الحاوية التى هي عليها مثلا لو قمت بتغيير الخاصية )عم لتساوي مه٠‏ 
لاداۃ مثل ٣٥ں‏ فان الاداة ستنتقل الی اعلی الفورم وستتمدد جوانبها لتصل للجانبین ۸۲وا & ٥۴۲‏ ] واذا قمنا بتغيير حجم 
الفورم فاءن الاداة مو حف با اعيا و هد e E‏ عرض الفورم هدا ما يشابه سلوك الاداه 
7۲ ونستطیع القیام بذلك ایضا بوضع الاداة ٥٥٤†ں‌B‏ في اعلی الفورم وتغییر الخاصیه هم۸ له لتصبح ,اما ٥p,‏ 
اhوRيمكنك‏ تغيير الخاصية »ء50 lتصlوي Top, Bottom, Left, Right, Fill, or None‏ 

والخاصية ۴|١‏ تقوم بجعل حجم الاداة بملئ الفورم التى هي علية او الحاوية التى تحتويها ولكن السؤال ماذا لو كان لدينا اكثر 
من اداة على الفورم قمنا بتغيير قيم الخاصية )عه لها باستنا القيمة ٠ه‏ اي اداة ستنفذ قيمتها اولا انا الفورم او الاداة 
ستقوم بترتیب الادوات بحسب ٥۲‏ ل۲ہ وہا)عه]ء التابع للادوات او ما یسمی مہ-2 الاداة التی تم وضع القيمه لها اولا هى 
التى ستاخذ موضعها اولا فالتالى والتالي. 


توف تقوم يمثال التعرف على هة الخاضية أك 
مثال : قم بوضع اربع ٣٥×18 ٥×‏ علی الفورم وغیر الخاصیة ٥ہ‏ ااا اں للکل لتساوي مں٣]‏ واجعل احجامھن وموضعھن على 
الفورم كما بالصورة 


EE vb4araؤb-جراجلا المخلب‎ TEK 


والان قم بتغيير الخاصية )عه بالترتيب للكل كما يلي. 
الاول : اعطيها القيمةً)وا 

الثاني : اعطيها القيمةمه1 

الثالث : اعطيها القيمة 0ا60 

الرابع : اعطيها القيمة ان۴ 


o۲ 
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وستكون بعد ذلك كما بالصورة‎ 


المخلب الجار ج-طاوة۲و4 طب 


الثاني 


or 
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أنشاء مشروع جديد فى بيئة الدوت نت 


تعالوا نتعلم معا كيف ننشئ مشروع جديد فى بيئة الدوت نت 


أين تنشأً المشاريع فى بيئة الدوت نت وكيف يتم ذلك ؟ 


من الفرو قات الاساسية بين بيئئي فيجوال بيسك ١‏ و بيئة الدوث نت انه بمجرد ضغطك على زر 
موافق عند ٳنشاء مشروع جديد في بيئة الدوٽ نٽ فان فيجوال سٿوديو دوٽ نٽ يقوم بائشاء كل 


الملفات و تخزينها في مجلد بالاسه الذي اخثرذه 0 المكان ن الذي اخترنه. 


عند إنشاء مشرو ع جديد من نوع وندوز يقوم”فيجوال سنوديو بإنشاء ما يمى بالحل» وهو عبارة 


عن نطبیق پمکن أن کو ي آکثر من مشروع. داخل. هذا الحل يقوم فيجوال ستوديو بإنشاء مشرو ع 
e e ea aT.‏ 

واحد کما بود بائشاءِ نسولج داخل هذا لمشروغ. 

لاش نشاء مشرو ع قم بالخطو لواث التالية : 


ا“ قم بفتح برنامڄ فيجوال سٽوديو دوٿ ئٽ. 


Ez Ecit View Tools Window 


New Propect... CtrleN |‏ ل2 
pen Project... Ctrl +‏ 3 
E? Open File...‏ 
lose‏ 
Ltrl+Shift+5‏ الدع av‏ ا 


DSEEF 


Recent Projects ۴ 


Emit 


أو 


o 
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File Edit View Tools 


0 


فم باختیار 4p 11٥2101‏ ۷110078 تم اکئب اسم 
لمشرو ع ٥4101‏ امم 4ء۴1۲ My‏ ثم انقر علی زر موافق 


New Project RA E lL 


Templates: 


Visual Studio installed templates 


Windows Class Library  Lonsole Application My Movie Collection Screen Saver Starter 
Application Starter rt Kit 


My Templates 


search Online 
Templates... 


A project for creating an application with a Windows user Interface 


ly FristA pplication 


ت )ل کے 


o0 
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ما لدی كدث ؟ 


بمجرد ضنغط على زر موافق قام فيجوال ستوديو بائشاء حل مکون من مشرو ع واحد 
اسمه My ۴1۲٤۲141‏ هذا المشروع یحتوي على نموذج واحد اسمه ۴۵۲۳1.۷0 


ل لاحظ ن امنداد النموذج هھ هو ا۷ و شذا الامنداد ينم اناو د يناء کن اأأحة التي 
اخترت أن تكتب بها التطبيق. فلو قمت باختيار لغة 6#لتكون لغة كتابة التطبيق فَإِن 
امندادالنماد ج سوف يكون CS‏ وهو اختضار م8121 .٤‏ 


ETTI N ESE 


. Fle Ed Hw Fmt Ball Oelıg Oi Toi amekbew Community Hdp 
TEL LELE EELS EC LECE LET 


hat EE | Farm vb (evap Start age | 2 X8 

rr E‏ چ ڪڪ و و ي 1 temmet‏ دا 
k Pointe rem O als SÎ mr FriciApplic ation‏ 
FF BackgraunaWeala! f Mr Fraject‏ 
Fy Binding gato 1 TI FommLals‏ 

Ti Bindingseares 

| lal kftan 

| E Cheeks: 

| FÊ Checbedlıstan 

E] Calar[ialeg 

| FH Comin 

| Î Cantsalinu ap 
| Î btaênrlihew 

i Dat 

| FH Or TimePiekel 


` a] DirketafyErkty 
TY Directap Seach ا‎ E | | 
` Damar Up Dini WOWEZEF E 1 


| O Eros Bilal Acton Campi 
ا‎ Einil= opp ta Dirt Da nt tapF 
ûl Fekete Cınaomı Taal 
| FlerliyarFanal Luoms Taalf 
3 Falderromreialag Fe Hamit Frmlrh 
8 Farilliialeg] 
1 raport 
ك‎ N Bl Artin 
| TE Hao 1 Hier The flê ialaîak û this liil aril 
EE teplopment proces! 


Eels 


qis e KHE‏ ا 
iı FE Frapalies‏ ا Firî‏ 


°٦ 
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التعرف على مكونات فيجوال ستوديو دوت نت 


نافذة مستكشف الحلؤل 


توجد في الجهة اليمنى في بيئة التطوير و تعتبر الأداة الأساسية للعمل مع الحلول و مع المشاريع 
وهي آداة ممائلة لنافذة المشرو ع d٥ W‏ ہ۷ ۴٣٥٥۲‏ التی كانت فی 

الإصدار السادس غير آنا تحمل إضافات أخزى مثل ‏ عرضها للمراجع التى يستخدمها المشروع. 

2 | و اي‎ e” a Û أ‎ + 4 | ST د ل "ص‎ N 

ويعرص مسصفش المشاريع کل عداصدر بر نامجكت سل مساریح و مگوناٽ› و شا يدر ج تحخٿ کل منها 

من اعضاء و عناصر› بحبث پمكنك بنقر ی منها مرنین ان تعرضهة فى مصمم النماذج ‏ لو کان 

من العناصر التي تعرض واجهة _ أو فتحه في محرر الكود لو كان ملفا نصيًا فحسب. 

كما يمكنك أن تظهر القائمة الموضعية بضغط زر الفأرة الأيمن فوق أي 


"سے 


عنصب حيٺ بمگنك 
2 | اب /*» 3 8 , : ا a es i #F PB‏ ا e 3z‏ ا r 2 ٣‏ | 5 

خيار الامر خصائص _ ۲۲00811185 لتعرصض ناقدة الخصائص؛ لنعدل خصائض هدا العنصر . 
وإذا كان المشروح يحتوي على أكثر من نموذج» وتريد ان تجعل احدها هو اول ما يظهر لك عند 
تشغيل البرنامج» فاضغط الأمر "اجعله كائن بدء التشغيل' اء زا0 مل۲إه)؟ وه 56۲ من القائمة 


الموضعية. 


نافذة مستكشف الحلول 


 Saltıtîon Explorer 
OEE 
3 My FristApplication 
BA] My Project 
. ES] Formlvb 


YOUSSEF 


o 
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إذا أردت الانتقال إلى أي عنصر في المستكشف يمكنك النقر المزدوج على هذا العنصر. 
على سبيل المثال لو كان لديك أكثر من نموذج في نفس المشروع فإنه يمكنكة الانتقال من 
نموذج إلى آخر بالنقر المزدوج على النموذج الذي ترغب فيه وسوف يظهر أمامك. عند 
اختفاء نافذة مستكشف الحلول وتستطيع إظهارها من خلال 1+41+1)© أو القائمة 
View ® Solution Explorer‏ 


اضافة عنصر أخرة إل المشر و ع فاذا كنت نر بةاضافة نمو ذج أخر ال المش 

عص ا E‏ دري ود اکن کن وون 
الذى أنشأته. قم بما بايا : 

١-انقر‏ بزر الفأرة الأيمن على اسم المشروع - في مستكشف الحلول- لتظهر لك قائمة 
اختر Ad‏ سوف تظهر لك قائمة فرعية lخûر Add New Item‏ 


Ri - 2 Ç7 eh ETE 1 Fr LT Et Ta 
a FL - 8 Fai TT ا‎ 
mg EN EL A EEA) TO RE TIEN dS SA HR NE "ٍ : 
ا‎ “FIFI = CT FT Fr | ۳ ۴ 
n ۹ | 1 8! NE | | E, ا‎ hh i ETT Fh 
ا = گگگ‎ ۲ 
3 2 
1 

کک ا 

كگکگگگگگکصگگگگذگګکگګګگگگ ت 
GD 3 .‏ 


E Build 


Eebuld 

Publish... 

3] NewRkem... Addl 1 
i] Existing Item... 
Lj New Folder 


Atlel Reference, 


Accel Web Eeference.,.. 


Debut ۴ 


ej Windows Form... 


LIser Coritrol...‏ ا 


r" 
Nm 1 
EIN 


@ Module... 
چ‎ CASS... 


Eenarmmeê 


I, Properties 


°۸ 
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پیفې ) إلى المشرو و 


٠ HTML‏ حتجت ت إلى ذلك. ما رید ا نضیفه الي مشروعنا هو نموذج من نوع 


ویندوز وهو ما یوجد باسم ۴011۳ 11107 قم بالتظليل عليه. سوف تلاحظ في الاأسفل 
مربع نص لاختيار اسم النمو مودج الذي تريد إضافته. تستطيع تغييره أو ترکه كما هو. 
اضتغط على زر 0-۵٤1‏ 


Addl New Item - My FristApplication > 
| 
Templates: 


Visual Studio installed templates 


Wincdlows Farm Dialacy Explorer Form MDI Parent Farm Aboiıt Box Losin Form 


4 MM 0 8 ۰ 


oclule Dataset SOL Database Lser Control 


2 
YOUSSEF 


Text File 


My Templates 


| Aã blank Windows Fort 


| Salrtîon E=plorer r 1L 5 


٠ة‎ | لعا تھ‎ E El 


| 
3 ly FristApplication | 
:-- [ad] My Project 
< Ea] FormlLvb 
ا‎ E] Form2.wb 


°۹ 
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صندوق الإدوات 


يوجد في الجهة اليسرى في بيئة التطوير و هو المكان الذي يحوي الأدوات المستخدمة 
بئاء ال لتطبيقات گما بد یظیر لك 


Tanihox NAX 
4 All Windows Forms ا‎ 
k Pointer 1 
1 Background Worker 

7# BindingMavigator 3 
وا‎ Binding Source 

Button n 
CLheckBox 

ê CLheckedl ıstBox 

3#] ColorDialog 

E4 ComboBox 

E LontextlenuıStrip 

DataûrıdView‏ ا 

| Dataset 

i: Date lımePicker 

lfs| DirectoryEntry 

ial UirectorySearcher 

| DomainllpDown 
 FErrorProvider 

| EventLog 

Fileystem Watcher‏ ات 


Fi FolderBrowserDralog 
1) FontDialog 

|" | GrouıpBox 
HelpProvider 

4 2 HScrollBar 

aj Imagelist 
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يوجد اة طرةالإضافة أداة إلى نالاج ماكاهى كما يلي : 
3 1 
مخبط النمودج. 
ا عر طربق النقر المزدوج وذلك بالنقر المزدوج على الأداة - انه ألما ثل الثالبة چ 
وهو ما سيضيفها إلى النمودج. 


Il‏ ا 


S8‏ النسخ ولك ہنسح اداه مو جود مسقا غ النموذج وشل لد لصقها غل النموذدج. 


E 
4٠ ا۶ا 1 : ا ء ۹ چ ا ¥ ا ۾ 5ة 1 چ‎ x 2 
شل الإضافاث الجذبدة لی لبدة الدولا للا لبها بإخكصل بلصندون الادواٿث شي انك‎ 


نستطيع إضافة مدخل جديد إلى صندوق الأدوات أو حذف أو تعديل و هي إضافة قوية للتحكم 


بتنظيم الأدوات 0 


ولإضافة شريط جديد 1402~ قم بالتالى : 


-١‏ النقر بزر الفأرة الأيمن على صندوق الأدرات لن" مول 


القائمة التى تراها ثم اخثر ا14 أ۸ 


1١ 
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A All Win : : 

3 Backgı ho اھ‎ 

 Bindin Choose terns... 

9 pi in 

Bınclin Sort tems Alphabetically 

o Reset Toolbox 

ڪڪ ص ص ص و Check)‏ 

H8 Checkl س‎ Adda a ell 
| Fi Fale Delete Tab 

Comb Rename Tab 

E Lorikê Move Lp 
لر‎ Data Move Down 

mı] DataSê - 


2 DateTirmnePicker 


| UirectoryEntry 
A DirectorySearcher چا‎ 
| % DomainllpDown 
O ErrorProvider 

EventlL od‏ او 
ا 


F* FlowlLayoutPanel 
Tt FolderBrowserDralac 
` | FontDialog 


I Filesystem Watcher 
"| GroupBox | | 


سوف يفتح لك مكانا لكتابة أسم الشريط كما بالشكل التالى 


۲ 


1 ڌ‎ înî 
1 el 5 1 


Timer 

A Printing 

lk Pointer 

i Pagesetuıp Dialog 

Bz PrintDıalag 

PrintDocument‏ ا 

PrintPreviewControl‏ ا 
re" PrintPreviewDialog‏ 
Dialogs‏ ھا 

lk Pointer 

5| ColorDialog 


Fî FolderBrowseê 


FontDialog 


22| OpenFileDialog 
3) SaveFileDialog ک‎ 
ك‎ | 


There are no usable contrals 
ın thıs qroup. Drag an Item 
onto this text to aclcl If to the 
toolbox. 


A4 General 1 


There are no usable controls 
ın thıs qroup. Drag an Item 
onto this text to aclel It to the 
toolbox. 


1 


4| 
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ويحتوى طقدوق الأقوات على الأشرطةالتالية: 


:Crvstal Reports Jü تقار‎ 


وبها الأدوات اللازمة لإنشاء و تصميم التقارير المختلفة. النسخة التى تأتى مع الدوت نت نسخة 


اد اھ 


محدذو دة الامگانذات . 


افو اعد الببانات' واو5: 


EE‏ 98 % ج ٣‏ الاي يي يي کا 1 ا ۴ د ا جه ا و تج آي ا 
ونحصوی على الادو اٿ التي نسنحدمح لاصتال بقو اعد البيانات و قر اعد و نحدبب بياناتها. 


:Windows F01105 " i aدنی "تماد الو‎ 


2 ۱ : = ر ص ا 8 ۴ = 3 
وتحتوي على الادوات التي تستخدم مع نمادج الويندوز. 


:Web Forms 'تماذج الاٹترنٽ"‎ 


وتحتوي عل لو اٿ التي تستخدم مع تفاذج الإنترنت وهذه الأدواتك Web Control‏ تعطے 


سهولة فى تصميم تطبيقات الانترنت. 


٤ 
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الجزء الثالث هنا تبدأً البرمجة‎ 


المتغيرات و الثوابت الفصل الاول 


المتغيرات 
المتغيرات تعتبرمن بين اكثر اجزاء البرنامج اهمية. 
والمتغير : هو احد توابع البرنامج الذي يستطيع تخزين قيمة 


هذة القيمة يمكن ان تكون رقم او حرف او بيانات اوهيكلية تتكون من انواع اخرى عرفنا ان المتغير يتكون من قيمة بقى ان 
نعرف ان البرنامج يستطيع استخدام ومعالجة هذة القيمة و ان يجري عليها العملبات الحسابية اذا كانت رقم والعمليات على 
البيانات الحرفية كالدمج والبحث والقطع وغيرها اذا كانت حرفية كذلك العمليات على البيانات الاخرى كالملفات الصوتية 
والرسومية من مقارنة وانشاء الى اخرة . 


هنالك اربعة عوامل تحدد سلوك المتغير بالبرنامج: 


-١‏ نوع البيانات: 
وهي نوع البیانات التی یمئلها ائnتiير (integer, character, sring)‏ الخ„ 


۲ مجال او مدى المتغير: 

وهو المجال الذي يمكن للمتغير ان يوجد ويستعمل فية فمثلا لو قمنا بالاعلان عن متغير بداخل دوارة ۴٥۲‏ فاءن مجال استعمال 
هذا المتغير هو بداخل هذة الدوارة فقط ولا نستطيع استعمالبة بخارجها ولكن لو قمنا بالاعلان عن متغير في منطقة التصريحات 
ای قبل اي حدث او دالة فاعن مجال استعمال هذا المتغير هو في كل اجزاء البرنامج ويسمی في هذه الحالة امطهای اي مرئي 


من قبل الجميع 


۳- امكانية الوصول ومدى امكانية التخزين: 

هي تحديد امكانية الوصول الى هذا المتغير من اي موديول اخر بالبرنامج فمثلا لو قمنا 

بالتصريح عن متغير بموديول واستعملنا الكلمة المحجوزة مدا للاعلان عن هذا المتغير فاءن هذا المتغير سيستعمل بداخل 
ذلك الموديول فقط ولكن لواستعملنا الكلمة المحجوزة ءام للاعلان عن هذا المتغير في قسم التصريحات العامة في اعلى 
الموديول فاءن باقي اجزاء البرنامج من فورم وموديول تستطيع الوصول لهذا المتغير هذا 

بالنسبة لامكانية الوصول او مجال عمل المتغير اما بالنسبة مدى امكانية التخزين فهذا يعني كم اقصى حد للبيانات يمكن للمتغير 
استيعابها وسنرى الفروق بين انواع البيانات وامكانية استيعابها للبيانات لاحقا 


٤‏ عمر المتعير 
وهو تحديد كم من الوقت ستكون قيمة هذا المتغير صالحة للاستعمال. فمثلا لو قمنا بالاعلان عن متغير داخل اجراء فرعي 
بواسطة الكلمة المحجوزةم 01 


Dim x As Integer 


فاءن هذا المتغير سوف ينشئ متى الاستدعاء بداء وسيدمر هذا المتغير متى انتهى الاجراء ولكن لو قمنا بالاعلان عن هذا 
المتغير بواسطة الكلمة المحجوزة ٠iاه]ء‏ فان قيمة هذا المتغير لن تدمر عند نهاية الاجراء بل سيظل المتغير محتفظا بها 
الانواع المختلفة للبيانات: 


Boolean 
Byte 
SByte 
har 
shori 
UShort 
Integer 
WMinteger 
Lorif 
WMLong 


Cecirmal 


Single 


Cou ple 


String 


Dale 


Object 


SIFLICTUFE 


ZA bytes 
1 tyte 
1 tyte 

ZA lytes 

ZA lytes 

A lytes 

4 lytes 

4 lytes 

E lytes 

3 bytes 


16 bytes 


4 bytes 


FE bytes 


Variable 


3 bytes 
4 lytes 


Variable 
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True or False 

Oto A55 nSsigned byte) 

-‘1A8 to 12AF (Signed byte} 

O to G55 35 nSsined character) 
-FA, 76B to 3A, 

Û through 65,535 lnsigned short} 


-A, 4F. 483,048 tO 2147,4183,0417 


Û through 4,204,067,205 (unsigned Integer} 


AAT TTA OTO, BDA TTS BOE to A23, TTA O36 BDA TTS BOT 
O through 18,4416, 4407 3,700,555 1,6 15 (Unsigned long} 


Uto +-F,228, 162A, 5 LAG 337.593041300. 335 with no decimal point. 
Oto +-T7. OPP E1625 14261337 O33 0335 with 28 places 


-TAUAFAFSEF3IE to -1.40120F8E-45 [(negalve values) 
1.4U120FE-45 10 34U22 FDEF3S {(posflive values) 


-.fF PFO TFACATISTOEF IOS to 4O SOASH 1AOAAIE-324 (negalrve values) 
4.940050454 240544E-324 10 1.TOFOIF1 348O ISFOEF 30B {(posfive values) 


Cepentling oni thie plalform, a sîrinq can hold approximately Oto 2 
Dillion Unicode characters 


Jaliuary 1, OOOT OOO to December 31, 000 15050 Û 
Points to any type of dala 


STrUuctuIre members have their own ranjes 


ملاحظة . 

ان التعرف على انواع المتغيرات والاختلاف بينها مهم جدا لمعرفة اي نوع بالضبط يمكن ان اتعامل معة فمثلا لو قمنا بمثال 
صغير هو تخزين رقم اكبر من 2,147,483,647 داخل متغير من نوع ۲موه]ہ1 لن يقبل ذلك المتغير القيمة المعطاة لانها اكبر من 
امكانية استيعابة في هذة الحالة يجب ان يكون نوع المتغير وها او ماطںه لان كمية استيعابها كبيرة. 


انواع الرموز. 


الرموز بالفيجوال دوت نت لها مهام خاصة كما هو الحال بالفيجوال بيسك ٠‏ فالرموز تستخدم للاعلان عن انواع البيانات 
المختلفة وهذا جدول مبين بانواع البيانات مع الرموز التى ترمز اليها وهي من النوع الرمزي الغير لفظي 


2 

me | ga 
LC 
em | 


فمثلا لو اردت ان تعلن عن متغيران احدهما نوعة 
وا والاخر نو عة وہ¡Sir‏ 
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Dim x&=5 
Dim y$=""salem4it - Youssef" 


وكما نعرف فاننا ملزمون بالاعلان عن كل المتغيرات في برامجنا ١١‏ كان الخيار 
Option Expاicit On‏ مفعل اما اذا کان غير مفعل فنستطیع ان نكتب اسما المتغيرات واعطائها اي قیم 
من دون تحديد نوع البيانات ملا 
الرمز: P1۴‏ 
Dim x=10000000000‏ 
Dim y =" "salem4it - Youssef"‏ 


وتستطیع تعدیل الخیار ii1ام Option Ex‏ من القائمة وا٥۲‏ وتختار sہOpİio‏ 

ومن شجرة العرض نضغط علی وہoااںuاہSo‏ dہھ‏ ءاcمزہا٥‏ وثم نختار وtاں‌ه]م٥‏ ۷8 او نستطيع ان نعدل هذا الخيار بكتابة 
العبارة "0 †ا‌iام×ع‏ نام0 للتفعيل في منطقة التصریحات العامة او 0۴ اا‌اام×٤‏ ۸٥ام0‏ لالغاء التفعیل ویجب ان تعرف 
ان الاعلان عن المتغيرات مع تحديد انواع البيانات التى سوف يتم تخزينها بالمتغيرات مهم جدا وذلك للتعامل مع الذاكرة بشكل 
افضل وسبب ذلك اعلام الذاكرة بالمساحة الفعلية التى تريدها متغيراتك لتخزين البيانات كي لا يحدث خمول 

للذاكرة بسبب حجز مساحة كبيرة منها لمتغيرات غير معروفة النوع ورغم كل هذا فاءن الفجول بيسك دوت نت حل مثل هذة 
المشكلة باعطاء نوع من البيانات للمتغير بحسب القيمة المسندة الية فمثلا 


P4۴ الرمز:‎ 
Dim x=10000000000 
Dim y =" "salem7it - Youssef" 


المتغير × من النوع و١‏ ه! والمتغير ر من النوع وہا١Š‏ 
وهنالك ايضاء بالفيجوال بيسك دوت نت انواع من الرموز تسمي بالرموزالحرفيه وهي تقوم مقام الانواع التى تدل عليها وولكن 
طريقة التعامل معها ليس هي نفسها التى استخدمناها سابقا مع الرموز الغير ابجدية وهذا جدول موضح لذلك 


[ 
LC. 
3 
Tt 
e, 


JSRor 
ا‎ 

Single (F for “floating point") 
Double (R for “real”) 


Lhar (note that this i5 a lower case “"c”") 


ج 


والان ناتي لكيفية الاستخدام افرض انك قمت بكتابة التالي 


۹۷ 
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P1۴ الرمز:‎ 
X=100L 
Y="A"c 


وهذا القيمة الاولى وہه! والقيمة الثانية من النوع ٥٠2۲‏ ولكن يجب ان نعلم اننا لا نستطيع ان نكتب المتغيرات بالشكل السابق 
الا اذا کان الخیار 0۴ ااءاام×٤‏ نام0 غير مفعل كذلك يسمح لك الفيجوال بتعيين انواع القيم باستخدام رموز حرفية 
مثل 1 & للبقيم السادس عشرية 0 للقيم الثمانية 
الرمز: P H1٣۴‏ 
i = 100 ' Decimal 100.‏ 


i = &H64 ' Hexadecimal &H64 = 6 * 16 + 4 = 96 + 4 = 100. 
i = &0114 Octal &O0144 = 1 * 8 * 8 + 4 * 8 + 4 =0. 


ايضا يوفر لنا الفيجوال الكثير من دوال واساليب التغيير بين انواع البيانات 
أستخدام الوسيلة_( )ماص هلمج لتغير تنفيذ البيانات الناتجة من الأمر ( )ل٣۸‏ 


Randomize) 


و هذا الأمر يجب تنفيذه مرة واحدة قبل أول تنفيذ ل40١”۸.‏ 

في السطر الخامس يتولد رقم صحيح يأخذ قيمة من (1) إلى (5) هذا الرقم يتم 
تخزينه فی المتغير "١۴١ء٥5"‏ ولتوضيح هذا الأمر آگثر نفتر ضس j Rnd) ji‏ 
القيمة ”0.46705“ وعلي هذا فإن قيمة ×R140(‏ 1+5 ) تكون ”3.33525“ و سيتم 
تخزين القيمة(3) في المتخير "اعإءمS"‏ لأنه من النو ع "ععع†م!]" . 

السطر السادس يوضح الدالة 80×0»امد1 و الداله عباره عن برنامج صغير يأخذ 
قیم كمدخلات تسمى المعاملات ( sأرعساعھ)‏ ویخر ج نتیجة تم (Reıın Value)‏ 

ثال لذلك هناك دالة لحساب الجذر التربيعي متاحة في ) gi ( Visual Basic. Net‏ 
أخذت هذه الدالة القيمة (9) كمعامل فإن القيمة (3( هي القيمة النائتجûة (Return Value)‏ 


هده الد الة فی هذا المثال . 


نفس الشىء ينطبق على الدالة ([×80٠ام.][‏ فهذه الدالة تعرض نافذة تحتو ى على 


إشارة إدخال ومربع كتابة لمستخدم البرنامج لكى يدخل ما يريد؛ وكتابة المستخدم لإشارة 


الإدخال هي معامل الدالة (sأامعمسسععف)؛‏ والمعلومات التي يدخلها المستخدم في مريع 


الكتابة تعتبر أيضا ال‌) Return Value‏ )؛ علما بان )Return Value)‏ تکون من النو ع 


"8اا" حتى لو ادخل المستخدم ارقاما وعلى المبرمج ان يقوم بتخزين Return)‏ 


g( Value‏ طباعتها. 


1۸ 


Prog : Mohamed Youssef 


المتغيرات و الثوابت الفصل الثانى 
أولا ٠:‏ المتغيرات 


قبل البدء فى الدرس أحب أن أنوه أن الى أنه هناك بعض النقاط المفتوحة فى الدروس السابقة والتى سنعود اليها بمزيد من 
التفاصيل فى حينه 


ومن أجمل ما قرأت فيما يتعلق بالمتغيرات هذا الدرس 


رالان سدور الي درل مساریه ومدنریات إطار عمل )و٥۴۲2‏ ۸8 , یي ان اشم لك مرینه 
إلى اقثر من 10 طبقات» ولكئي فضلت تقلبص العدد- للتسهيل علبك كما رى في اعد الشكلبن التالببن. 


توصبف اللفة المشتركة وإ NÊĞĞF‏ 
[] (المفا الوسيطسه) | 

Visual Basic NET, Visual CE NET, ) 
لماع فدات ۱5.1 | خددات باع ) ۱ تڪ‎ 


windowsê |‏ 
نطبيقات أ۴ا .م؛ 


ر و 


۹۹ 
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مکئبه شات ھ٣‏ طا s5ھاC‏ ع845 (نسمی أیضا مکتی غت NET Framework Class Library‏ . ( 
هي عبارة عن منات الات الموجودة ثي عشرات ملفات ال ]01 تعتبر كذزا غاليا يسيل له لعاب العبرمجين الجادين؛: 
حبث تحتوي كل ما تحناجه لإنجاز برامجك ومشاريعك بدءا بتقديم ات لوصف الببانات الأساسبة ( ك عنىماہ!| 
ti9:‏ ) انی ادارة خرج ودخل المنفات وم 55و۴ أ۴ 0/| , مسارات النَنفبدٌ وم الكة ع۲" , الصور 
واٹرسوم نمكدج Windows F0 mM‏ , ادج Web Forms‏ , الإاتصسال بقراغد الببانات آ٤N, A۸00‏ رغرها 

بالنسبة للغة التنفيذ المشتركة عRuntim )©1R( - Common Language‏ لھی موحد لایر جح لذات 
آ8 , الأخرىء كما آنها المسنولة عن عمليات إدارة انذاکرة Memory Nana gٍِ me"‏ , تفريغ مصادر التظام 
باستخدام ناء eاانC Garba j٤‏ اخطاء وٹت التiنږذ Exception Handling‏ . 

اخبراء لظام النشتيل الذي كنك من ثبت اطار عمل wor‏ م ھ۴ E۲‏ یه خو ست ہ آل۷ فقط ؛ راکن فد 
تري في القريب العاجل نظم تشغيل اخرى داعمة له 


ها أسلوب الترجمة على الفور ومأاأامص هع عص آ٣ |٢‏ وبال - (١ال)‏ , وهي تقنية تقوم بترجمة البرنامج عند تنفيذه حبث 
ينتج أفضل شيفرة تتناسب مل الجهاز الذي سيعمل عليه البرنامج مما ينتج عنه نتائج إيجابية جيدة ( هذا عند الحئيث عن تحسين 
الكقاءة 0٣‏ أخوعأصآام ) وحتى تعلم كيف يحدث ذلك تابع الشكل التالى :- 
قق اكب باللغة التي تربدها 


YBE.NET 


| سيتحول برنامج بلغة ا أو ا۷8 


ترجھ وہ ااام صد 


3 

0 

ر 

i) : 

OES 1 
JIT 


لزع ستتم عبلية تغبذ البرنامج باستجدام 
الترجمة على الفور ١١ل‏ 
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٠‏ ألا بكرن قلع من كلمات اللفة الأساسية (تلك الثي راما باللون الأزرف)., مل اا؟ و۴۲ و ۴| وغرها.. ان الجطة 
الثالية غير مقرل UIin Sub A3 Integer‏ 


ولكن لو كنت مصرا على مثل هدا الأمر؛ لبمكنك ان تضع الاسم بين وسين مضلعن [ ].. هه الجملة مقبرلة: 
im [uk] Ma FLejsr‏ 


لكن عليك في دل موضع تسنفام ليه المتعر ان تحيطة بالقوسين المضلين : 3 sub]‏ 
٠‏ الايزيد عى 255 حرفاء وهر رفم كبير بالفعل بها بكلي. 
٠‏ أن بترن من تة واحدة ا تتخللها المسالات.. ويمفن استخام الشرطة المنخنضة "_" للفصل بين مقاط الكل 
بدلا هن المسافات. 
٠‏ لاييداً ارام وإن كان من الممكن أن تتوسطة أرفام؛ أو بثتهي بها 
٠‏ الأيطوني على أي من علامات اللتصيص أو الأنواس أو النقطة "": ولا علأدات السليات الحصابية أو عسات 
المقارنة الحايية أو المنطقيك فكل هه القلامات محجوزة لوظائف أخزفى. 
٠‏ غير سوح بنكرار اسم المنغير داخل تفس النطاق: فلا يمكن نمر يف منغيرين مالين في الاسم داغل تفس الإجراع؛ 
وان كان من الممكن تراز نس اسم المنغير لكن لي إجراءات فة 
والمتغيرات في لغة الببزيك تتجاهل حالة الأحرف #بأأورة#ومأ-#ووع: نالاسماء فورم ر ووورص د ۲A6‏ كلها 
منكالنة: وتشير للف المنغر.. معى هذا آلك لا تسنطيع اسنام هذه الكلمات لتعريف ثلاثة منغبرات مخئلفةء لكلها اسما واحذا. 


انواع المتغيرات 


القيمة التي يمكن تخزينها 


32708 - را32‎ 2 Short OR Int16 
0 - 65535 1 UShort OR Ulnt16 


û - 4294907245 


SFFEET PNET LU PENC PFFEETPIVETELET FCT) 8 Long OR Int64 
O - 1844é 744073 7091615 4 ULong OR UlntB4 
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E ۹_۹ E E E. 1 ۹ a E .F a . E E N.‏ نا 


-3. 402828+03 - 3.4028 2e+038f TIlE Ê 


-1. 79 Se+308B - 1.79769 e+308 a [E 
- 2P SIBA 142043 3753354390330 - ۴ 
Decimal 
EFFI LRU FI MEETECELTNELENEEETIN mm | 


أي خرف أو رقم أو رمز أو ... 
أ 


Eoolean‏ 1 التيسة عإم] أو عاد 


. تأريخ أو وت بكل التلسيقات المختلفة‎ DateTime 


a 1 aaa a a 1 a 1 r 1 n 1 


محاضرة معدة من محمد الحاج 


نغیرات الرففuة Numeric Variables‏ 
ل للمتغيرات الرفمبة أنواغا عدبدة تبقا لحجم الد ردقه الشربة.. وعليك انت أن نقد النوع اللي بلاسيك؛ واضغا في الاعغبار 
ن الأعداد ذات الال الشرية الأكيرء تكون السلبات غليها أبطا من الأغداد الصعبحة والأغداد ذات الدفة العشرية الل 


UD 
العمليات على الأرقام‎ 
لن تون هناك فاندة اذا كلت ستض الارفام في منبرات؛ دون ان تستطيع أن تجري لبها بض العلبات الحسابة., وف‎ 
الجدول النالي علامات السليات الحساببة الأساسبة:‎ 


V۲ 
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علامة القسمة.. ويمكن أن يكون النائج عددا صحبحا أو به أرقام عشرية.. فمثلا: 7/2= × 
ستعطى الناتج 3.5. 

علامة القسمة أبضاء ولكن الناتج هو العد الصحيح لفط.. فمنلا : ٣‏ 
سنعطي النائج 3. 


ويمكن أداء نفس العملية باستخام الدالة 1٤‏ لو شنت آلا ترنبك بين علامتي الفسمة المنشابهئينء 
وذلك كالئالي: )7/2( X = Int‏ 

إحدى علامات الفسمة أيضاء ولكنها تعطى البافى من الفسمة فحسب.. فمثلا: 2 7104 X=‏ 
سبعطي النائج 1 الذي هو عبارة عن بافي الفسمه. 

لأس.. فمثلا 2 × 2 × 2 تكتب رياضيًا بالصيغة 2 وتكئب فى البرمجة كالئالى: 2١3 ٠‏ 
ولو أردت أن تعر عن الجذر التكعيبي مثا فارفع العد لأس (1 + 3) كالتالى: (1/3) 2۸ 


ويجب أن ألفت انتباهت إلى أ همية و سح الآقو اس فى العمليات المتداخلة. و ذلك شی تضمن صخة اجراء العملية بالترتيب الدي 
تريدها به.. ان الترتي,الطبيعي الذي بجرى به ۷8 العمليّات الحسابيّة يسيزا تبعا للقواغذ التالية: 
- يتم تنفيذ ما بين الأقواس أولا. 
- إذا لم تكن هناك آقواس يتح تنفيذ الأسس اولا. ن 
ثم يم تثفيذ الضرب والقسخة. YODESEF‏ 
- ثح باد دلك يتح تنفقيد الجمع والطرجح. 
لهذا فاح الصيغة (4^)1/3 
تعطي الناتج 2 وذلك لان القوس ينقذ أولاء فتصبح العملية هي الجذر التكعيبي للعدد 8.. ولكن لو أزلت الأقواس كالتالي: 
81/3 
فان الناتج سيكون 2.666666 وذلك لأنَ الأس يتفذ أولا. فتصبج العمليّة كالتالي: 8/3 
بقي شيءٌُ هامٌ..ماذا لو آردت أن نزيد قيمة متغبّر بمقدار 1 مثلا ؟ 
في هذه الحالة سنقوم بالتالي: 5 X=‏ 
Y =x‏ 
صارت قيمة المتغير 6ا X=¥۷‏ 
حيث اعتمدنا على متغيّر وسيط جعلنا قيمتةه هي ناتج جمع المثغيّر الأصلي فع الواحدء ثم نقلنا قيمته إلى المتغيّر الأصلي. 
ولكن مثل هده العسلية تتكرّر مرارا في البرمجةء حيث تحتاج مرارا لزيادة قيم المتغيرات او إنقاصهاء أو ضربها في رقم... إلخ. 
فلو كان على المبرمج ان يكتب هده الخطوات في كل مرّةء لصارت البرمجة جحيما لا يطاق! 
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وبالتالي يمكنك أداء هده العملية في سطر واحد مباشرة كالتالي: X= X+ j‏ 
لإرل وهلة سنبدو لك الصيغه غريب ولكن حاول ان تفرأها كالتالي: قبمة ‏ الجديدة تساوي قبمته الثديمه + 1. 
ولا يشرط أن أجمع على المتغير الرفم 1 لحسب» فهذه العملبات أيضا مباحة: X=X+13‏ 
A=‏ 
5= 
A=XtY‏ 
ولا يقتصر الأمر على الجمع فحسب بل يمن إلى باقي الصلبات الحساببة: 
القاص المتفير بمقدار 4 ' A=X+4‏ 
ف ضرب المتفير في 2 ' 2" A=‏ 
KS‏ فة ١‏ ر 9" X=X/9‏ 
YOUSSEF‏ ي 8 
رفع المتفبر للأس 3 ' X=X^3‏ 
کان هذا هو ما اعناده مبرمجو 86/., ولك «ناك تسهيلا إضافيًا تقذمه لك ۷8.6 عن طريق استخدام الرموز =+ و = 
و =* و | ر ^ و... والجدول الثالي يريك كَيفية استخدامها: 


الطريقة المختصرة المكافئة | الطريقة التقليديّة 
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: نطاق الأعداد‎ 
والأن: اسنخدم الكود التالي لإاختبار انواع المتغرات.. ستجد الا نسنخدم خاصبَّة "اصفر فيمة" عuاة۷مآا: و "كبر فيه"‎ 
عرض نظاق کل نوع متها‎ VA UE 


Mea sa gels Saw {Tye " f Hyle.Minvalue f " E2 f YS Maral ss) 

ase ose op I"aBytc " & SOUytc.Onalıc & " Tz = #& SEyYES, Hava _Uc) 
Menage Pus Shew Shok " & Sort. MrVabie  " " Shor... Marwa ut 
HcasSagzlEor. Show "DyTES " & Dyrc.Mnvakir & " r e + ULC. Harm lic] 
HEssaıqlZEocx. Show ("iOtlb " & Inttlc., ا‎ GH” E " ¥ NTIS. MaKYTa SC] 

Mer saqgellox Show {MlnlLeqer " EST nleagêer.Minval ıs ê " o "f Meera Yaxal ıe] 
Hcssaq2Eoz Soho "intl " kk Intl inva lue ا ي ي‎ " E NLL aR a-UC 
Msa223aasEo0z. Shor {"Lsng " % Long :Min¥alus 4ã " ج‎ " &% LSr3.HeaXVal ss) 
Hrasagclorz.ghow {("inttd " & INCo4.OnYaluc & "Sz " &# DTZ IMIART3-UC 

Mesa qsREuos Sw ("BS inglsE " û BSingla Mina f Tr: " FF Sir @MasTaluz| 
Mesa qgEBos aE {("UublE " ê oblea inala f Tr; " Ff lEeult: Max vealus| 
Hcssaıq2Eox.Show {(SLccsimal " & Uccimgl.invallIz & " To " ë Decimal . SAzValur] 


ما لا نهاية والقيم الشادذة |لiخZرJ ‘Infinity And Other Oddities‏ 
يستخدم ۷8 فى الحسابات الرقمبة القيمتين "ليس رفم" لجل [التي هي اختصار لتصير Not a Numbêr‏ ء "مال 
نهاية" اام اء ودلك لاعلامك بان شبنا لبس على ما يرام فد تم في حساباتك. لتتخذ التصرف المناسب» بدلا من ان 
بعرض لك ۷8 رسالة خطا كما كان بحدث في الماغني. 


ھا لا :Infinity aıldi‏ 
ان بعض العليات الحسابية ۔ كالقسمة على صفر . تعطي ما لا نهاية.. ولو استدعيت الدالة "حول إلى تنص" و أ٣ ٦٥5)‏ 
على هذه القيمة؛ لكان الناتج هو النص "لآ٣‏ 1"۴1”.. فلتر هذا المثال: 


LLI ط‎ A5 8 ubles کے اا کے چ‎ 
HagEoxl & 7 Û 


سيظهر لك النص "رام أ؟م!" في الرسالة. 
سيب آخر لمالا نهاية, هو قمة دد كبيراجذا على عدد صغير جدا جداء لدرجة تجعل الناتج يتجاوز حدود المتغير 
المزدوج.. جرب هدا المثال: 


i Î ma ت‎ 1 _ mM gz ا أ 1 ا‎ 1 = TFT = ۳ 1 Ea 
E ır LAISSE و 4 لا اا‎ SMaAlLlYaL ZE 11 5 
| 3 


{Larger 7 SnmallVar) 
أيضا سيظهر لك النص "رام آ۴ما" في الرسالهة.,‎ 
واذا ما عكست هذه العمليةء بقسمة العدد الصغير جدا على الد الكبير جدا: فسيكون الناتج صفرا.. الواقع ان الناتج سيكون‎ 
غذدا صغفيرا صقرا جدا جداء ولكن المتغير المزدوج لا يستطيع التعامل مع مثل هذه الأغداد القريبة جدا من الصفر.‎ 


رقما 2: YOVSSEF‏ 
هده القيمة توضح ان ناتج عملية ما ليس معرفا: ليس رقماء ولا صفراء ولا خث ما لا نهاية. 

فمثلا. ستنتج لك هذه القيمةء لو حاوئت أن تحسب اللوغاريتم لعدد سالب أو لو حاولت أن تقسم صفرا على صفر (0/0): 
فهما عملبتان غير معرفتان رياضياء وليس لهما معي.. جرب هذا المثال: 


Dim Yarl As’lcukle = J, Vari As Double = f 
MsgBox (Va VaFL | 


la! e 


ستظهر لك رسالة تعرض النص: "3۸"., لاحظ أك لو جلت فبدة ۲2| صغیرة جذا مثل 1-299 فن النائع س 
صفرا, ولو جالت قبمة ۷۲1 صفيرة جذا؛ فسيكرن الذالج ما لا نهابه, 


Vo 
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اختبار وحود "ما لا نهاية" و" ليس رقما" ‘Testing For Infinity e ١a١‏ 


الأمر بسيط: للتحفق من هاتين الفيمتين؛ استخدم الدالتين 


: "إنة لبس رقا" ل 3| و"إنهامالا لهاب" 


۷اnاnfاواء‏ اللثين تجدهما من أغضاء المتفيرات النفرد؛ والمزدوجة , ولمعرفة إشارة الما لانهاية, اسئخم 
الدالتين: "نها ما لا نهاية سالبة" 61۸۴ ۷او 58| و" انها ما لا نهاية موجہ" رام nf‏ |sPositiveا.‏ 


واليك مال تو ضيكي: 


1 ۲ I FT Uae? 
pie wm Varl 7 Var 


Than 


8 1 ١ E 1 1 4 EE 
Dim Varl = ll, Var = lL, E Az Uoup Ll! 


1 
fe F 
ا‎ 


Double. TIInE1nî 1t] Than 


ILE ٣ CEN 


Tf Double. ISPositivaInfinity{Reaault) 


1 ۳ ت | ۳ 1 AN N.‏ 
| فا إقعم لث حلذا.. 1 حن الاشنفرال [ Msg! IA‏ 
i‏ 1 ا 
فا 1 تا #4 شاا ق l=‏ 
e | - 4 " iî‏ 
[ 1 فتم شغ حداء.- لا عكر الاأستفر ار )80ند 


هذا الكود سيعرض الرسالة "ليس برقم" [۸14., ولكن لو غَيّرت فيم ۷4۲1 إلى 1> فستنتج ما لا نهاية موجبة 


ولو غيرتها إلى 1١‏ فستنتج ما لا نهاية سالبة, 


"1 E 


Failura w=Falg 
A 1 - 


راضع جذا أن الصيف الأولى تختصر خسة اسطر في سطر واد فقط! 


الجتغيرات النصضصة string Variables‏ 
يٿم تعريفها کالتائي: 


الان يصبح بامكانك ان تضع اي نص مها كانت مكوناتة [حروفه هول » آرقاد: علامات تنسیق. 


وکن آنا ای عورا ای 2ار کر 
وهدذه الجمل ثريك كيف تدتخدم المتغير . التصي: 


"ولك تاقخاتك ارت كنتت صد ا 


۲ REDE E: hy a تا ا أطو] س ا‎ a ا‎ E E 


Din S2msTexlT Bs STELLA 


.. الخ] ومهما كان طولة 


pF ^, Fir" FI 
2 UIT] 


طبعا لاحظت ان اللص بوضح بين علامتي تلصيص.. وها بالتاكبد سيدفعك للتساول: مادا لو اردت ان اضع علاسة اللقضنص. 


فى شذه الحالة يجب أن تكتب آربع علامات تنصيص كالثالي- 
وهناك حل آخر؛ هو استخدام الدائة Cr‏ 1 
سال أخر سيراودك: ما الفارق بين التعسببرين التاليين: 


للتعبير عن علامة التنصيص كالتالئ: 


Jim ASTFIÎinq A2 STIİiNnG = rm 


LIR Ais LEIANY MS SLIP 


Tr AT e1 Trl IE = FEO 
Uim FSTIEINQ A3Tstrcing چلال لا ي ي‎ 
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إن كلا المتفيرين بحمل أيمة مخئلفة عن الأخر: 
- فالمثغير النصي وم51 بحئوي على سن حروف» وهي "2" و "5" و "" و "0" و "0" و ٠"0"‏ 
بينما الد الصحبح ۸۸0168۲ يحتوي على رُم واحد هو 25000. 
2- بما أن کل حرف بتم نخزينه في وحدني ذاكرة ول8 2» فان المنقيّر النصي بخزن حروفه السنّة في 12 
وة ذاكرة بينما بخزن الد الصحبح الدد 25000 في 2 ( وحدنان ففط) . 
ولكن برغم هذه الخلافات» فان بامكانك أن تسنخدم المتغيّر النصى و١أ)۸5‏ في العلبات الحسابيةء ونستظم المناير 
ال رمي 8۲ ط۸۸۲ في العملبّات لصب حبث بوم ۷⁄8 بالعلبان اللازمة للنحويل بين النوعين (ما لم تمنعه من القباد 
بذك باستخدام جەلۂ م0 „(Option Strict‏ 


دمح النضصوص :Concaten ai0‏ 
ماذا لو أردت أن نلحم نصدن؛ بحيث يننج نص جديد بجمع الاين معا" 
بسيطة,. اسلخدم علامة الجمع "+" كما اعندت في استفدامها بين المتفيرات الْرفْيةً: 


a + LNIVLCISILY 


ولي 2 اتر الصو س بالغرة شل الأرقاد. فان بامگانك E‏ 2 اه ر ا ت 8 التاارة: 


KX  " Treaentabion ك2‎ 


- " Tresêntatiin 
:+ ولو كنت لخشى من الارنباك في فراءة الكود بين الجع الحسابي ونشبيك النصوص. لاسنخدم العلامة & بدلا من العلامة‎ 


Lim &A ûs SLIÎNg للل"‎ 
2 = = TF Fl 
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Character Yariables ةuèر=ل| المتغیرات‎ 
هي متغيرات تخجز وحدنا ذاكرة 85ر6 2؛ يمكن أن تخزن فيها حرفا واحا.. ولظرا لأن الكمبيوتر لا يعرف شينا غير‎ 
لأرام وأي شيء يُعفظ به يجب أن ينم نمئيله بأرقام تلل علبه؛ فان اللمبيوئر يمل الحروف بأرقام من النوع "عد فصير بدون‎ 
.65 فتلا الحرف "و" بمئله الرقم‎ ..لnsاgned‎ Short lاntegers‎ )ل|n†16( شار"‎ 
لهذا فان بإمكانك نحويل الاعاد الصحيحة إلى حروف: باسنفدام الذالة [)2؛ وتحويل الحروف إلى ارقام: باستخذام الدالة‎ 
[إع5ه.. جرب مأ بلي:‎ 
MiqEuz# (Auc { "BI ) 
.65 ستجد أن نافة المخرجان تعرض الرفْم‎ 
Dim Charl, CAAT? 2a Char ؛ بسئنك استخذام جملة كالنالية لنعربف منفيرات حرفية:‎ 


ريإمكالك ان تضع فيمة ابنذانية في المتغير الحرفي عند تعريفه. سراء أفالت حرفا ام نصنا [فى الحالة الأخيرة سبتم وضع أول 
درف فط ئي المتضر).. جرب ما بلي Liu Chari Au Char = "a", hszcd Au Chal = "ABC"‏ 


Mrs saq2E2x .Ahoa (Charl) 


Metts RE ha (ha rr) 


ستجد أن شاشة المخرجات ستعرض ما يلي: 


لكن الطريفة السابفة لن تسل إذا كان اختبار "التحويل افق" فعالا © إء ام5 موأام0: لهذا يجب استظام الطريفة الأئية 
س عن الحروف: ا Wim Lharl As #har‏ 
حيث يخير الحرف ¢؛ ۷8 أن ما بين علامتي التلصيبص حرف وليس نصا.. ولي هذه الحالة يجب أن بكزن ما بين علامتي 
التلصيص حرف واحذ بالضبط: حبث ن بقبل ۷8 جملة كالتالية: Diu Charl Au Clar = “abit‏ 
ن وضع حرف ع بجوار علامتي التنصيص هر طريقۀ ۷8 لکې پرمز للحروف؛ ويهکن اسنظامها نې اي موضع التالي: 


Linûlharl As ChAT ¢ 

hy: 1 HI Fx 1 . Al 7‏ ب" | a‏ 
والملقير الدرفي يلك بعض الوسائل الشيقة: مل "إله حرف" ٣عااعاء|‏ و"انه رذ" ا و"إله علامة نري" 
unetuation‏ ءا“ ... الج , فلو جربت الجمله النالية: } McssaqcBax. Show (Chaz. IaDiqit ("J‏ 
: زل mM E‏ 


لظهر لك فی نافذة المخرجات گلمة "۲۲۵" , جرب أيضا ما يلي 


Mcssaq2Eoz. Bho [Lhazr. lsFuncEuation 


Tim A Aa Chat e 


Meu HAgsBux . Show (Chass TuDigIL a) | 
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im û A" MAT = 


MzasaqcCBok. Sho (Chaz, lEDiTIT (2‏ 
ستحصل على نفس النتيجة.. طبع يمكك أن تلاحظ أن الدالة ٣اؤ‏ ا180 هي داله مشثركة 514۲80 يكن استظامها من امثير 
الدرفي؛ أو من لي النوع الأساسبة C188‏ .. بل على يسن استظامها من أب دال اتجها حرف.. جر ب لمل الئلي: 


Mim # Ar SlLring = "MI" 
Ara 91 CEO ay [7 Tar: UII; اا‎ 


ستدصل لى تفس النتبجه وهي ع٣1‏ ولئنا ناج لض الإبضاح لالداله "عررف" إو اظ رف الدرف الذي ربد 
معرفته في التص: ولرجع لك ها العرف.. هدا مغ فلاعظة ان العرف الإول لى الل يوجد في الموضل رفم ل.. إلى ها بسن 
ارف حيث بمئن اسنطاد جملة ئالذالية: MaaaqeRoz2hrw (XCar‏ 
حبث سبظهر نك في اة المخرجات ما بلي 1 
حبذ إن "2" هو الدرف الموجود في الموفع 1 (العرف الثاني) في الل 

لگن با آن الال ()4۲5٣اع‏ ترجع حرلا إن أبن نطبيق ودل لرا ف ليها گالئلي: 


Cons. HritSLINAKhaAZr, ISLIGIMA LATS LIJ} 

وتلاعط ألا لم ترسل حرفا دال "انه رفم" أو 50| كما فعا من فل ول ارسلنا لها المنعر النصني )ل وموضع الدرف فيه: 

الاي نريد اختبار و ردا ام لا.. ولا باس في هذاء فالدالة ٣ال‏ |50| لها تعريفال يخلفان فط لى لوعبة الساملات الني تفبلها 

الال أطهما يمن أن ترسل فيه معاملا راخدا للذالة؛ هر الحرف ادي رط اختباره: رالاخر تسل ليه معاملين لال أحد 
اللصوص وموطغ الدرف المراد اختباره فيه. 


المنغبرات الرمنيه 5ع اداة ۷a‏ عا0a:‏ 
يته تخزين متغبّرات اناري والرقت بتلسبق خاص كأعاد مزدوجة؛ بحيث يمل العدد الصحيح التاريخ: ويمثل الجزء العشري الزمن 
وبتم تعريف هدا اللوع من المنفيرات والكتابة فبه بطرف كالناليه. Lim MyPata Aa Nate‏ 


MyUals = #llFUlFELUD# 


MyUatc \I1FOLIFEOUd b:24:11 PMT 
HyData "Nor l1l, Ub" 
H0۴2 دال اون" تعطيك لاهم والرقد انی )سد‎ 
Mi 


تلاحظ انا لكنب الناریخ بطربفتين: إما كناريج رمي امگتوب بين علامٽي # او تاريخ نصي موب بين علامتي تلصيص 
يك سيتم تحويله ضفنيا في الحالة الأخيرة؛ إلى تنسبق التاريخ والوفت المنامب. 

تما أن بامكانك اسنظام الدوال الجاهزة التي بمنحها لك ۷8 انتعامل مع التاريخ والوفت.., فمثلا: يمكنك استخدام الدالة "فرق 
التاريخ" ()041801۴؛ لحساب الفرق بين تاريخين مختلفين؛ وبالوحة الزمنيْة التي تختارها [إسنوات , أشهر , أسبوع, أيام ؛ 
ساشات. دقان ٿواني e‏ اليك شد المثال: لحساب د | ايام لن ي ت#شناها في ۽ لد د الألفنة: 


im Lys As Long 
Day LatcUll iM Datclhtcerval. Dayê lL EULl, Nami] | 


۷۹ 
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المتغیرات الكا نات اع [(0: 
شذا انوع سطع نين آي وم من الائات سواع من الانوا ع م السابفك أو من آي گان أخر نعرفه اللع أو تعرفه آئت. إن في 
هذا النوع العام بمكن أن نض فبه أي نرع من الببانات دولما قلق! للأسف: لا تبدو الآمرر بيده البساطة؛ ففعل ذلك سيكون له اثار 
جانبيه سنه ففبل ان يستخدم ۷/8 هدا السفير الان ل بد له ان بعرف نوع البيالات الي به اولاء ليبوم بسليات التحويل 
المناسبةء للتعامل مع هذا النرع من البيانات.. فمثلا: لو كان المثغير الان بحنوي على غدد صحبح؛ فلى ۷8 أن بخوله إلى 
نص قبل لصقه بص أخر.. مثل هذه النحويلات تمثن عبنا على سرعة البرنامج.. لذا فعليك استخدام المنفير الكائن عع زات في 

خالا الضرورة فكب 

Lim Yaz is bc 
Var : Haq E E “ . GEtETYpc.LsString) 
Yar >< S.1 : HegqUcg (Yar. bEtTypE, TostE1ng) 
Yar “A cC ; MSFEOK{ YAT GST TYp2.ToSTtrIng| 
Ar = Hol} f MEJlOZ (VET. TET ype L'ortTtrIng) 
ar =, "raha" 2 Mad ear tet Type. Toft] 


المنغرات الرمنيه :02٥ ۷2 ٣اةادا e5‏ 
يتم نخزين متغبران اللاريخ والرفت بتلسبق خاص باعاد - بحبث بم الد الصحيج الاريخ؛ ريل الجزء العضري الزمن 
ولم نوربف ها الوع من المنفيرات بالقناب فيه بطرف نال Lim Myrate û Tata‏ 
Myla = FIlFULFELURF‏ 

MyDatce ALU/UIFAUU bd: l1 PMI 

2 E 1 I" 


ذالم اإن" تعطيك لتاشم وال قد IC ow) ul‏ 


لاحظ الا لكب الناري نطریشن : إا ناريخ رسي ۽ ملوب بن لامي چ اب ۽ اريخ لصي ملتوب بين اقلامتی تنصيس "". 

حب سيم تحريله ضنبا في الحاله الأخبرة؛ إلى تلسبق الثاري والوفت المذاسب. 

كما أن بامكاك اسنام الدوال الجاهزة الئي بمنحها لك ۷8 للنعامل مع الناريخ والوفت.. فسثلا: بمكلك استخدام الدالة "فرق 

الناريخ" [)١۴ا04180؛‏ لحساب الفرفى بين تاريخين مختلفين وبالوطة الرمبْة التي نختارها [إسنوان , أشهر , أسبوع, أيام 
ساغات دفائق , اني ...).. اليك هذا المثال: لحساب غد الأبام الي ششناها في هذ الأللية: 


im Lys As Long 
Dayê. DatcDlfMDatclhtcrval. Dayê lA HLFEUALÎ, Haw{)) 
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كتابة البرنامج‎ 


تستطيع كتابة البرنامج من خلال محرر الكود 


كيفية الوصول الى محرر الكود 


ا- النقر المزدوج : عند النقر المزدوج غل ی داد فان ذل سوف بقود يفك الى محرر 
الكود. 


نفلك إلى محرر 
الموج 


و الأيقوئة التي بجانبها نفلك إلى وضع تصميم 


CTT TOE 
KNEE | 
iE WindowsAp 


ig Lata Sotırcê® 
v1 X 
Forml System. Windows, Forms,Fo | 
2ھ‎ 2/8 # |8 
Showlcon True ا‎ 
ShowInTaskbaı True 
E Size 300: 300 
azep Stylê  Ãııto 


StafPositlion WindowsDefauil 


ll Tag mM 
| Tent For mil 
| Text : 


The tet assoclatercl with the control, 


۸1 
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Brin] to Front 
LT S<êond to Bacl 


Align to rig 


Lock Controls 


Select Forml’ 
i ۰ 1 
Lapy 

Paste 

Delete 


| Properties 


7 FormlLwb" | Form L.wb [Des nj’ ` Start Page 


E [Declarations] 


E Fub1lic T1IASS Forrml 


End LTIass 


YOUSSEF 


۸۲ 
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وللرجوع لواجهة التصميم‎ 


ُ rrr nae 1 . 
„ Forml.vb" rt Page ¥ XK 


FormlLwb [Design] Sta 
4 Forml ١ | Declarations) E 


HH Fublizc Class Forml # 


e 1 
End Class ۱ 
ك‎ 
۷ 
1 
\ 


A۳ 
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: با مميزات محرر الكود في بيئة الدوت نت‎ 
نوجد عدة مميزات لمحرر الكود في بيئة الدوت نت يجدر بك معرفتها لأنها تسيل‎ 
العمل أثناء عملية البرمجة» سوف تتغرض لخمس ميزات منها‎ 
نمط الاختيار المربع : ويمكنك من التظليل الدقيق لما تريد من كود؛ و يحصل عند‎ 
ضغط زر 1ه و تحريك الفارة لأسفل‎ 
التحرير الذكي : حيت تقوم بيئة الدوت نت بترتيب الكود الذي تكتبه ترتيبا يسيل‎ 
عرضه و فراعته من ترتيب جمل الشرط و جمل التكرار. لن تحتاج بعد اليوم إلى‎ 
غ۴15 لوضعيما بوضع ستوازي فسوف تقوم بيئة‎ 1٤ البحث عن جملة 1 وجملة‎ 
الد نت بعل نلك نبابة حل.‎ 
أكمال الجمل : مئل إكمال تركيب الجمل المشهورة مئل 0ل ]1,عaءc ]عة‎ 
Selec Case وغيرهاءو لن تحتاج بعد اليوم إلى حفظ صيغة جملة 1۴ أو جملة‎ 
فبمجرد ما نکب جملة 1 نم الشرط نم تقوم بضغط زر ۴11۵۲ سوف تقوم الدوت‎ 
نت بإكمال الجملة نيابة عنك.‎ 
Edit %3 Advance % Word Wrappiig Jilخ‎ ùم‎ : تجز ئ الجمل‎ 
عند إعمال هذه المميزة سوف تقوم آلدوت نت بتقسيم الأسطر الطويلة إلى سطرين أو‎ 
أكثر التسهل عملية قراءة الكود.‎ 


ترقيم الأسطر : تتيح لك هذه الميزة.الترقيم الألى لأسطر الكود. 
Tool - Option —- Text Editor - General - All Langeuage — LIne Numbers‏ 


طريقة دقيقة لتظلبل الكود 


PFeiwate Bub Button1l LlickFIEFYTal sender A5 PRFILEM.mjJEztE, Bye 
Dim LONtEEO IAF As Lontrol 
Tor Each <GnErolVar In He.LontEol= 
IF TrpeOf ControlVar I13 TexXFBox 
II TEIMICOHTET TTAE TEHT] = rr | 
erRef.SEtError [Sontrea lVar , 


| 
Else 


٤ 
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الثوابت والتركيبات‎ 
الثوابت‎ 


شل الراضي: اللرابت العدذية الصحبده بنعامل معها المنرجم على أنها من النرع ٣هووام]‏ , والأعاد العشريه من الوع 
Doublê‏ 


aml mae ff TI Tm mmm ! = 
= I el لالا‎ Intsgs1 ا" اسا للوخ‎ 


NaqÜox {5.a} "011018 قيمه من النوم‎ 
lr wı 


ا لل بمگنك تطبد وء اللابث أزبادة سر عة إسلك الق فته استخدام الل "|" وع Long‏ , ابل "3" وع 
he‏ , الیل "0" نرم او صاع , اليل "۴" لر ع واوم اة 


u 
الاإستاذ الندال اأسرع وذللا لحدم اخراء الفجريل الواد‎ 


ر لثوابث المسماة شبيه بفكرة المنفراثء إلا أن فيم ار بث السساة ل يكن تطبلها رفت الث وذ ها قشل شا 
اناع شملية الل جد بناج ویم اشا ئي بف البرنام هلي | EE‏ ا | اسم الكلمة النحوزة ١٣ع‏ 
ریف ابت جلبد, 


vonat NAME - "Saba Univeza1ty 
Nag (HAME) 


فيد نوع الثابت أمر مفضل لريادة السر عأ نما بكرن إلزامي إن فكت اة 0 51101 10۸م0 


CUNuL NAME Au SLriug = " Saba Iuiverslly 


التركيبات 


عبر الزمن ومع الأبام: سيدا ثعبف أنواع خاصة بك في برامك الجلبة تمرف بالركيبائ ٠‏ والتي دعتها لفقا المشمبزة ۷8.۸6٤‏ 
يلوذ ,وهنا ساتطث عن أهم التركييات وهى اللوع E۸103‏ و التركيبات من وع 3غ۲ لاع لا])5 كما ساخصص لثرة كام حول 
التصوفات وج۸۲ ولدك سننحدث عن كل من فانم المصفرفة جوأارج۲۲ و المجسرعات النوعية ءأ٠م٠6‏ . 


\o 
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الترکیبات من نوع وہ ںہم 


لسفنڭ تعردف نوع معن من اثواء اتشر اث الى لح تكن فو جودة بالاصسل فى اللفك وتخام أحثتاحاتك الخاصة , نن بسر فط حصر 
سجال لهذه اليم الئي ستسندها من خلال ما يعرف بالمجاميع المرفمة ( م0ا٤ة۲‏ ٤نامع‏ ) , وهنا يمنا القيام بذك دن خلال 
استخدم القلمة المحجوزة K0"‏ لتعريف تريب جليد إما على مستوى الوحدة البرمجية #اماكه , أو داخل تركيب أخر ولكن 
من انوع ۲٤‏ ااع 5)٣‏ , كما يجب مراغاة بأنه يمئشنا كتابة هذه القيم باللغة التي نريدها . 


هذا المثال شرف فيه ركيب يمثل ايام الأسبوغ : 

Enum Day 
Saturday 
Sunday 
Monday 
Tudsday 
Wednêsday 
Thursday 
Friday 

End Enum 


والان ينك اسنغذام الترئيب السابق ونعريف منغيرات جليدة منه: 

Ûim x As Day = Day.Friday 
ضمن الثوابت؛ فهي كالثرابت المسماة - الئي تطرفت لها سابقا - حبث أن تيمها‎ E" "5 تفنيا: تصنف التركببات من النوع‎ 
, نستبدل ناء عملية الترجمة‎ 


لم لرل إليها المنقيرات من نفس لوع الأركيب او فيم الأركيب مياشرة: 


ر 


1 Li i i = 
EDS 


Dim A As Day = Day. Friday 
MessageBox.Show(%) 
MessageBox. Show(%. ToString) 


۸٦ 
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الترکیبات من نوع وع ںاcںs),u‏ 


يعرف هذا النوع من الذركييات بالالواع المعرفة من فل المسنظم وعم رآ لعماfع0‏ ٣عولا-‏ (01لا ) , بحبث نمك من دمح 
ألواع مختلفة من المتغيرات وضمها في رئبب أو تله راحدة. استظم الكلمة المحجوزة 51١/610۲١‏ لتعريف تركبب جدبد: 


Structure Person 
Dim Name As Strinğ 
Dim Age As Byte 
Endl Structurê 
: لم عرف متغيرات جديدة من هذا الثركيب وتتعامل معها كالمنغيرات العادية‎ 
Lim MS Aş Person 
MS.Name = "Saba" 


: ل 
ا 99 = MS.Age‏ 
It ' Saf AOE‏ 
ش : MsgEox( MS.Namê ) Saha‏ 
MsgBox([ MS.Agê ) ' 39‏ 


المزيد أيضاء يمئنك نسخ فيم التركيبات بانسيابية كاملة كما تفعل مع المتقير اث العادية: شربطة أن تون التركببات متطابقة : 


Lim MSZ As Person 

MSA = MS 
MsqEox(MS2.Name)} ` Saba 
MsgqEox(MS2 Age) ` 99 


لا تنس آن الترگیبات من نوع ٣٥‏ اع ں٣٤5‏ يمكن أن تكون متداخلة ى عاوع آي بحتوي يبعضها بعضا: 


Structure Person 
Structure FersonAddress 
Dim City As String 
Dim Country As String 


و 
OMS SSF‏ 


End Structure 

Lim Name As String 

Dim Age As Byte 

Dim Address As PersonAddrêss 
End Structure 


A۷ 
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الوصول إلى عناصر الثركيب المحضون يثم من خلال التركيب الحاضن نها بكل منطقية:‎ 
Dim ms3 As Person 
ms3.Narmêa = "Saba" 
msš.Age = 99 
mss.Address.Clty = "Talz" 
= "Republic of Yemen" 


بالاضافة إلى المتفيرات. علبك معرفة أن التركيبات من نوع #إلااع ل٣5‏ في ۷8.8 هي تركيبات مطورة ومرنه جدا جدا 
[ مثل الئركيبات الموجودة في C++‏ ) , فهي نمكنك من تعريف عناصر إطافية في داخل التركيب كالطرق sله‏ ۸ء 
ز الخضانض şعاا‏ عم "ro‏ : 
Structure Person‏ 
ي Dim Name As String‏ 
Dim Age As Byte EERE‏ 
تعريف طريقة أو إجراء 
Sub ShowDatal)‏ 
MsgBox(| Namê & " "& Age)‏ 


End Sub 
End Structure : 
: مرة اخرى؛ يمكنك الوصول الى علاصر التركبب واستعاء طرفة بنفس الطربفة الانسبابية‎ 
Dim MS4 Aş Person 
NS4.Nameg = "Saha" 
NMS4.Age = 99 


MS4 ShowDatal ) 


أن المشيدات ۲5عاع ۳0٣5٣‏ دعومة بشكل متفي في التركيبات من النرع sعر‏ اعم حيث أن الإجراء [ )سwعN Sub‏ 
معرف بشكل تلفاني في التركيب دون أن تراه . ولماذا تم اخفانه؟ وما الفاندة منه! الفائدة ببساطة إسناد قيم ابتدانية لمتغيرات التركيب , 
فلو حاوك إسناد القيم وفث التصربح تما فعلنا سابقا عند التصريح عن المتغيراث : 

Structure Person 
Dim Name As Strlnd = "Saba" ا‎ 


Dim Ağê Aš Bytê =8 E 


ع 
iF‏ 
یا سےا ے٠‏ ار 


End Structure 


۸۸ 
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سيظهر لك المترجم رسال خطاأً تفيذ باتك لا تسنطيع لعل ذلك وهنا بأئي دور المشيد المخفي إ ]سعل ان5 الي يقرم اساد فد 
بتدائية للمتتيرات [ 0 للمتقيرات الددية: ل شيء للمتغيرات الحرفية: وانقيمة واه للكائنات ) , مع ذلك: يتنك تع يف مشيد 
NW) (‏ ط5 بنفسك عن طريق نطبيق مبدأ بعرف باعااة التعر بف لعل دلك ؛ أضف وسيطات إضالبة مع الاجراء ( ]سم اة : 
Structure Person‏ 
Dim Name As String‏ 


Dlm Age As Integer 

Structure FersonAddress 
Dim CIty As String ر‎ 
Dim Country As String ا‎ 


End Strueturê 
Dim Address As PersonAddress 
Sub ShowDatal) 
MsgBox(Name & " " § Age & " " & Address.City & " "3% Address. Country) 
End Sub | 


Name = PêrsöonNamE 
Age = Person Ajê 
Address.CIty = PersonClty 
Addrêss.CoUuntry = Pêrsön Country 
End Sub 
End Structure 
رغم أن الوظيفة الأساسية نلإجراء ( )عل اباق مي السل کمشید الا آنه لن يئم اسندعانه بمجرد انشاء كائن من الثركيب فيا لو‎ 
صرعت عن متتير جديد بالطرف التقليدية؛ والدليل جرب هذه الأسطر.‎ 
Dim NS5 As Perso ` هنا ن تلذ انمشيد‎ 


MS2.Name = "Sabha" F2 
MS5.Age = 99 
MS5.Address.City = "Taiz" 

NMSS5.Adaress. e = فا‎ of Yemen” 


۸۹ 
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A۲۲جy المصفوفات‎ 
يمكنك اخبار الفجوال نت بانك تعرف هذا المتغير كمصفوفة بعدة طرق وأشكال أنظر التالي:‎ 


Dim myvalue(5) As Integer 
وهده صورة اخری:‎ 
Dim myvalue(5, 3) As Integer 
عندما تريد ان تضع قيماً بداخل المصفوفة الاولى فيمكنك ذلك بالطريقة التالية:‎ 
Public Class Form1 
Dim myvalue(5) As Integer 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 
myvalue(0) = 11 
myvalue(1) = 4 
myvalue(2) = 13 
myvalue(3) = 44 
myvalue(4) = 123 
End Sub 


End Class 
كما يمكنك تعبئتها بواسطة مهه ]1 في برنامجك كالتالي:‎ 
Public Class Form! 
Dim mycounter As Integer 
Dim myvalue(5) As Integer 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 
For mycounter = 0 To myvalue.Length - 1 
myvalue(mycounter) = mycounter 
Next 
End Sub 


End Class 


لاحظ اننا عرفنا متغير من النوع هموما وهو ۲ما٬ںهءرص‏ لاستخدامه في العدء اما العبارة ه۴ فهي ستبدأً من الصفر الى 
1 - ue.Lengthاvaرm‏ و Length‏ تعود برقم يمثل مجال المصفوفة وسوف تعود برقم ٦‏ كما عرفناها ولكنني انقصت منها ١‏ 
لانه يتم احتساب الصفر أيضاً. 
وبعدها أسندت للمصفوفة على الترتيب القيمة الصاعدة بداخل المتغير mycounter‏ 
ولكن كيف يمكن التعامل مع المصفوفة من النوع الثاني..؟ 
Public Class Form1‏ 
Dim myvalue(5, 3) As Integer‏ 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
MyBase.Load‏ 
myvalue(0, 0) = 1‏ 
myvalue(0, 1) = 2‏ 
myvalue(0, 2) = 3‏ 
myvalue(0, 3) = 4‏ 
myvalue(1, 0) = 5‏ 
myvalue(1, 1) = 6‏ 
myvalue(1, 2) = 7‏ 
myvalue(1, 3) = 8‏ 
myvalue(2, 0) = 9‏ 
myvalue(2, 1) = 10‏ 
myvalue(2, 2) = 11‏ 
myvalue(2, 3) = 12‏ 
myvalue(3, 0) = 13‏ 
myvalue(3, 1) = 14‏ 
myvalue(3, 2) = 5‏ 
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myvalue(3, 3) = 6 
myvalue(4, 0) = 17 
myvalue(4, 1) = 18 
myvalue(4, 2) = 19 
myvalue(4, 3) = 20 
myvalue(5, 0) = 21 
myvalue(5, 1) = 22 
myvalue(5, 2) = 23 
myvalue(5, 3) = 24 
End Sub 


End Class 
أنظر هنا قد تم تعبئة المصفوفة.‎ 
طبعاً يمكنك استخدام المصفوفة لأي نوع تريد أنظر للمثال الثالي:‎ 
Public Class Form!1 
Dim myvalue(5) As String 
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 
myvalue(0) = "Visual" 
myvalue(1) = "Windows" 
myvalue(2) = "File" 
myvalue(3) = "Copy" 
myvalue(4) = "Edit" 
myvalue(5) = "Cut" 


End Sub 


End Class 
الامر واضح تماما وسهل وبسيط جداً.‎ 
Dim myvalue() As String = {"'Visual", "Windows", "File'"", "Copy''} 
أو كما بالشكل التالي:‎ 
Dim myvalue(,) As Integer = {{1, 2}, {3, 4}, {5, 6}} 
ولكن ماذا أذا اردت ان تقوم بتغيير أبعاد هذه المصفوفات» عندها عليك استخدام العبارة "اهم كما بالشكل التالي:‎ 
Public Class Form1 
Dim myvalue(5) As Integer 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 


ReDim myvalue(0) 
myvalue(0) = 1 


End Sub 


End Class 


لقد عرفت مصفوفة من خمس اعمده ان صح التعبير تم في اأ Form_load‏ أستخدمت Red"‏ لاعادة تعريفها بعمود واحد فقط 
ولو حاولت ان تضيف عليها فستحصل على رسالة خطاء. 
وبالمثل يمكنك استخدام هذه الطريقة مع النوع الثاني من المصفوفات. 
اذا اردت ان تعرف ابعاد المصفوفة فيمكنك استخدام الامر الثالي: 
Public Class Form1‏ 
Dim myvalue1(5) As Integer‏ 
Dim myvalue2(5, 5, 6) As Integer‏ 
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
MyBase.Load‏ 
Msg Box(myvalue1.Rank)‏ 
Msg Box(myvalue2.Rank)‏ 
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End Sub 


End Class 
وبالرسالة الثانية ستحصل على الرقم ثلاثة‎ ١ حيث بالرسالة الأولى ستحصل على الرقم‎ 


كما يمكنك تحديد القيمة المعطاة اي الرقم المحدد في تعريف المصفوفة انظر التالي: 
Public Class Form!‏ 


Dim myvalue1(5) As Integer 
Dim myvalue2(5, 5, 6) As Integer 


Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
MyBase.Load 


MsgBox(UBound(myvalue1)) 
Msg Box((myvalue2.GetUpperBound(2))) 


End Sub 

End Class 
بالرسالة الاولى» وستحصل على الرقم > بالرسالة الثانيةء ولاحظ اننا حددنا رقم الخانة المراد قراءة‎ ٠ ستحصل على الرقم‎ 
لانها تحتوي على ثلاث خانات.‎ ۲-٠-۰ قيمتها وهي ۲ أي انها‎ 


كيف يمكن عرض ما بداخل المصفوفة...؟ 
كما استخدما >مط وء" يمكنك استخدام أي اداة لنفرض ×هط×ه أنظر الى الشكل التالي: 
Public Class Form1‏ 
Dim myvalue1(5) As Integer‏ 
Dim myvalue2(5, 5, 6) As Integer‏ 
Private Sub Form1_ Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles‏ 
MyBase.Load‏ 
TextBox1.Text = myvalue1(3)‏ 
TextBox2.Text = myvalue2(3, 2, 5)‏ 
End Sub‏ 


End Class 


او العكس يمكنك ان تضع بالمصفوفة قيم من الاداة >هط)×ه] او اي أداة أخرى لا فرق. 
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0 * 4 مھ 0 
الجزء الرابع : تطبيقات متنوعه 
كيفية عمل متصفح من خلال برنامج الفيجوال بيسك دوت نت2005 
قم بفتح البرنامج كما تعلمنا معا بالدروس السابقة وأتبع كما هو موضح بالأشكال التالية 


lew Project 2 ا‎ | 
Templates: 


Visual Studio installed tem plates 


5 li ا‎ ۴ 1 


Windows Llass Library  Lonsole Application My Movie Collection Screen Saver Starter 


Application Starter Kit kit 
My Templates 


أو 


search Online 0 USS 


Templates... 


A project for creating an application with a Windows user Interface 


ekse) Lancel 4 


! BEÎ Forml E | > 
ج 7 ا‎ 0 


YOUSSEF 
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قم بتغيير حجم النافذة " بيئة المشروع " الى ما يناسبك أو بأمكانك جعل بيئة العمل تظهر بملء الشاشة وذلك بأآتباع ما هو 
موضح بالأشكال التالية. 


Forml System. Windows, Fortms,Fo * 


NEA NE 
StartPositliaon WindowsDefaull 


Ta 
Tent Forml 


0 
TopMost False e 
Iransparencyk | 


من صندوق الأدوات أختر ما هو موضح بالاشكال التالية. 


۹٩٤ 
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وقم بأضافة تلك الأداة كما تعلمنا معا بالدروس السابقة الى بينة العمل ليصبح كما هو موضح بالشكل التالى‎ 


YOUSSEF 


ومن نافذة الخصائص رجاء عدل التالى 


هل لاحظت ما حدث به فضلا أخبرنى بما حدث ؟ 


من صندوق الأدوات أضف الاداة المشار اليها بالشكل التالى 
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ا 


| EF Web Brows êr 


ليصبح شكل العمل كالتالى 


قم بأضافة الأدوات المشار اليها بالأشكال التالية 


۹٦ 
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قم بأضافة الأدوات التالية وقم بتسميتها بتلك الأسماء‎ 


Refresh Jİ! Button2 
Stop gi! Button3 
Back Jİ! Button4 

Forward gi! Button5 


قم بتسمية الزر الذى بجوار المكان الذى يوضع به الروابط ۸1ل ٥ا‏ ه6 
الأكواد 


الزر الأول ضع له الكود التالى بمحرر الكود 


کود: 
WebBrowser1.Navigate(ComboBox1.T ext)‏ 


Refresh 


کود: 
WebBrowser1.Refresh()‏ 


Stop 


کود: 
WebBrowser1.Stop()‏ 


Back 


کود: 
WebBrowser1.GoBack()‏ 


Forward 


کود: 
WebBrowser1.GoForward()‏ 


يمكنك أيضا إضافة بعض المواقع المفضلة لك لتصل إليها بشكل أسرع دون كتابتها. 
لعمل ذلك قم بالضغط على أداة ×0ط oطاm٥C‏ الموجودة علی الأداة امم مم و اضغط على الثلاث نقاط الموجودة بحانب الخاصية 
Items.‏ 


ستظهر لك نافذة » اكتب فيها مواقعك المفضلة (كل موقع فى سطر) 


ضف زر آخر إلى الأداة امرهمP‏ و غير الخاصية save web page gİ! Text‏ أو ی نص ترید إظهاره على الزر يدل على عمله 
انقر نقراً مزدوجا على هذا الزر 
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WebBrowser1.ShowSaveAsDialog() 


كذلك يمكنك فتح صفحة قد قمت بحفظها .أضف زر آخر إلى الأداة امم هم و غير الخاصية Open yJ! Text‏ و أضف أداة أخرى 
من قائمة الأدوات و هى الأداة وه‌اه¡2٥ا۴"مم0‏ فى قسم وهاه فى قائمة الأدوات 


ملحوظة: ضع الأداة OpenFileDialog‏ فى أى مكان من الفورم لأنها فى كل الأحوال لن تظهر للمستخدم حيث أنه فى اموا 
n.ءasiطهناك‏ بعض الأدوات غير مرئية تظهر للمبرمج فقط ليستخدمها لكنها لن تظهر للمستخدم. 
انقر على الزر نقراً مزدوجا و اكتب: 


کود: 
OpenFileDialog1.ShowDialog()‏ 


WebBrowser1.Navigate(OpenFileDialog 1.FileName) 
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٥۴ 5۴ کيفية عمل کتاب ألکترونی‎ 


ا فیجوال بیسك دوت نت ۲۰۰٣١‏ 
1- اي اصدlار‏ مڻAcrobatj Adobe‏ 


طريقة العمل 
اوا افتح البرنامج 


Microsoft’ 
Visual Studio 2005 


Professional Edition 


This product is licensed Eo: 
egyptian hak. e] Microsoft visual Basic 
Hame 
Microsoft YWisual ZF 
Microsoft Yisual LFF 


This programm is protected Dy Urs, at Microsoft Visual 1# 
and International copyright laws 
a3 described in HelplÃêbout, TH  Yisual Web Developer 
2 ZUOS MicrasoR Corporation, 2 

All rights reserved, wrystal Reports 


ثانيا 
نفتح عمل جدید 


File | EdE View Tools Window Zommunity Help 


E ٣ EN EEFOJBEL... LtrlrShirt+N 
pen Fg website... 


Project Frarn Existing Lodê, 


نختار المحدد بالصوره (جاهل أنجليزى) 


Hew Project 


Project Cypes: Templates: 


la: اھا‎ Basic Yisual Studio installed templates 


H- 5mart DE GE] windows ûApplizatian GE Class Library 
GDatabase : ER Zonsolê Application E] windows Lontrol Library 
; i SEarter Kiks A EE] web Lontrol Library JE] windows SeErYÎcE 
. isal LF iE ErnpEy Ptojëck El crystal Reports Application 
El Yisual 1# 
Hl. wWisual ++ My Templates 


BH: Other Project Types . 
3 iloearch Online Templates... ن‎ 


YOUSSEF 


solution Marne: Lreate directory For salutian 


ok 
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رابعا‎ 


» 


ننشئ فورم جدید كما بالصوره 


solution‏ اا 
Er‏ 0 ا 


BE 


Projectê' (1 project) 


Rebuild 


lean 


| Publish... 
4 Add Reference, ,, 


I Yiaw lass Diagram 


mT 
ij] New Item... 


Existing Ie... 


a 


Add Web Reference, ,, 


: Mem Folder 


Windows Form... 


` User Control... el a5 SLartLlp Project 
TT Component, 


Module... 


as5... EE. 
EE 
Palit! 
Proje 
Fra] 


Lnload Project 


i Properties 


خامسا 
نختار المحدد 


Ternplates: ا ا‎ 
Yisual Studio installed templates YOUSSEF 


Tinos Forrii Fî Dialog “>: Explorer Forrn 
E | MDI Parent For ا‎ About Bi نو ا‎ Farr 
[=| Splash Screen 3 E] lass £] Module 
ê Interface cB] Component Class Ê LOM Class 
u Dataset SAL Database 8 Report 
2 rsta Report yl lser Zontral Inherited Farr 
[| Inherited LIsEr Zontral FA Seelam Control FÎ web Lustom Loantral 
aA Resources File E] Seti file e | ode File 
ا‎ lass Diagrarn كا‎ ML File اا‎ #ML Schema 
ا‎ #SLT File 2 Text File 5 HTML PagğE 
ıa Bitmap File |b | Cursor File ۳ Icon File 
E3] Application Configuration File ا‎ Transactional Camponern™ 8 Installer Class 
HE] Windows Service 


ee‏ )ل ا 


Add New ltem - ProjectB 
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الأن طريقة تصميم البرنامج‎ 
اولا:‎ 
اصنع مثل هذا الشكل‎ 


قارئ كتب إهداء الى كتاب العرب 8 | 


YOUSSEF 


ثانا 
٥‏ اضغط كلك يساو اختر المحدد بالصورة 
E Date TimePicker 4‏ 
Label‏ 


ج س 


LinkLabel | 3  Zopy 
ListBox 


ا 


a 


TE 


3 ااا و 

EE ` Delete 

|_| 

HH 

HE 

ا 

2 Sart Iterns Alphabetically 
@ 

Reset Toolbox‏ ا 

labl| TextBox Add Tab 


TaulTip Mowe Lp 


Dr 


IreeYlewy Maye Dor 


ثالثا 
اختر الاداة المحدد 
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Choose Ioolbox Items 


EE Path Library 
[Î 3 vidensaft Flex Array 1 LINO SYSteErmSA\WSFLERS OLN :- WideoSofFE ¥5, ,, 
1 LIMOS SteEmSAYSFLENS. OLN. 4 videoSoFE ¥5, ,, 
LIMOS YSsteEmSA mrt, dll 
Documents and Settings 11Deskto,,, ActiveSkin 4.0٠... 
LC YINOTWS SSE SaA plugin, DEX Microsoft Acti¥ê,.. 
WINDOWS YStEemSalrmnrt , dll 
LIMOS StEMSA\MSA#N DCX 
Adobe Acrobat 7.0 Browser Docu,,., LHPrograrn Filesiadobelûcrobakt 7.Û,,.. Adobe Acrobat ,.. 
[Î BrowserProxy4 Class LW OTWSISYSteEMSA ATE] . dl AlETE 1.0 TYpE ... 
[| Calendar Control 11,0 Program Files\Microsoft OFfice{OF.,, Microsoft Lalen... 
1 | 9 


- a Texa gE 
` © 
VOUS 


رابعا 
ضعها على الفورم كما بالشكل 


رخ کنب إعداء الے كتاب العرب 
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خامسا 
اضغط على زر إقرأً مرتين وضع هذا الكود 
کود. 
AxAcroPDF1.LoadFile("D:/arabsbook.pdf")‏ 


شرح الكود 
ي انه عند الضغط على زر إقرأً يقوم بفتح ملف الم.)ههطءطهه الموجود على قرص ‏ في خانه 5۴1 ۶٥١٠إ٠۸×۸‏ التي قمنا 
باضافتها اضغط 5 واضغط على إقرأ 


ئ كب إغداء الى كاب العرب إ8 


بسم الله الرحمن الرحيم 
كتاب تعلم الفيجوال بيسك 


Atachmerils 


ا 
ا 
1 
ج 
ع 
- 
ےا 


wm YOUSSEF 


اخوخم محمد الفر ˆ 


5 
(| ii |F Pl ج‎ HHH 1 


٠ 


الأن احفظ العمل بصيغة عادية عن طريقة م۷جء 


4l SEE SAE, 1 in % 


۳ 


اذهب الى مكان تخزين المشروع وافتحة تجد مجلد في داخلة اسمةہ اط 
افتحة تجد مشروعك بصيغةم×م 


ويکون احیانا في 
C:\Documents and Settings\1\My Documents\Visual Studio‏ 
2005\Projects\Project7\Project7\bin\Debug‏ 


اذ کان اسمc]74مزهPr‏ 


الأن زر اهداء 
" ×0اووصإهداء الى منتدى تكنوبلوجيا التعليہ" 


زر تصميم 
" ×0 وء" تصمیم محمد یوسف " 


قم بفتح البرنامج وأدراج بيئة العمل كما تعلمنا معنا بالدروس السابقة 
ومن نافذة الخصائص غير القيم التالية كما هو موضح بالشكلين التاليين 


a | EF | E 
Sizer ptylê  Ãuııto 


StartPosition Windaygyfle 

اگ 5 

Text 

Toplost False 
Transparencyk Û | 
| LIseWaitCursor False 3 


LK. Ti 
- 


| Forml System. Windows.Faorms,.Fa =” | 
EEE 
MinımızeêBox [rue 
E MinmurmSize Û: Û 
pacity IE 
Padding J: Û: Û: Û 
RightToLeft Yes 
.  FıghtTalLeftLay True 


Showricon True 


E F7 ل‎ 


ليصبح النموذج النهائى لبيئة العمل كما بالشكل التالى 


اه الال الحاسبا 


USSG 
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قم بأدراج المكونات التالية الى بيئة العمل كما بالشكل التالى 


۰© 
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اليك الحاسبة ا‎ E) 


RadioButton Û) 


REadisButtand 
RadioButton | 


الرقم الاول 
الرقم التانى 


POMSSEEF 


وقم بأضافة زر تنفيذ كما أشرنا سلفا 


ثم قم بالضغط على بيئة العمل الرئيسية ليظهر محرر الكود ضع الشفرة التالية كما هوموضح 
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E WindowsApplication 1 - Mifefosoft VisûAlLBasıc 2005 Express Editiqrî 

File Edt View Project Bunld Debug Uata Tools Window CLommunity Help 
SES. CIBE EE EGE zg 3 HF BAF j 

| Toolbox ا‎ For m1.vb*"[ Form Lb [Design] Start Pagê 1 


All Windows Forms 3 For ml ا‎ {Declarations} ١ 


3 


ا 


ر 


Private Bub Forml Load{EBYVaLl sender As PRystem. Object, Bfval e As Satem . Er 


ا 


1 


Lr 2 


General APubIlic Class Forml‏ ك 


| Lim FirstMNum, SecCconANMum As Doub 1e] 
There are no usable controls In 


thıs qroup. Dragcy an Item onto ا‎ 
thıs text to adil If to the toolbox. ا‎ 


End Sub 
CLCEnA LIass 


TOSSES 


4| ت‎ I 
Realy 


آ ا 


Friar Bub Focml: Lod | ByIs1l menfeet hs EpeteEm.lh ier; Bal e le Egateh, BE 


Bg m1 


ir 1 


E1 Windus pplication 1 ~ Miura Vref Basir FIA Fapies: Eiistion : 

Elz Ed eî Faget Buk] Uektarg Uda Tank Winelnw Lmn Fel 

IE EN 4 OE | = ج ال ع‎ F e کے کک لک‎ e 
Fa aL." Faia kula [Dt gj | Sal Page 


ANN rele Far ai FF Bama L £ F CHAE 


ener Fuk Glu FOTIA‏ د 
EEE TE ml E OT Tala i ET EE ml mR‏ 
There ûrê û içablê canî o mı‏ 
Phi FE I FET aR Fart SRE‏ 
His tef bo adt # bo he Fool lei‏ 


Ed uk 


Fr iwata Fir EBmttanl CIIGkE [BF a 1 meEmnidler kha Syke. Theo, 
Firatim = Tet lrnr1] . Tek 
ean = Tet Enz È . Text] 
Ed 3ib 
E CJM 


ثم قم بوضع الشفرة المشار اليها سابقا 
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وهذا تطبيق أخر لأنشاء الة حاسبه متطورة‎ 


EE Faormîl 


Dim clearDisplay As Boolean 

Dim Operand1 As Double, Operand2 As Double ط¡بضئlبو هنا تكتب الاكواد في اعلى الصفحة‎ 
Dim [Operator] As String! 

تحت كلم اأ public class‏ 


زر رقم واحد 


کود: 


Private Sub bttn1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
bttnO0.Click, bttn1.Click, bttn2.Click, _ 
bttn3.Click, bttn4.Click, bttn5.Click, bttn6.Click, bttn7.Click, bttn8.Click, bttn9.Click 


If clearDisplay Then 

IbIDisplay.Texit = '"'" 

clearDisplay = False 

End If 

IbIDisplay.Text = Val(lbIDisplay. Text + sender.text) 
End Sub 


ولاحظ كتابة اسامي الازرار فی کود واحد 
كود زر الفاصلة في الارقام 


کود: 


Private Sub bttnPeriod Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttnPeriod.Click 


If IbIDisplay.Text.IndexOf(".'") > 0 Then 


Exit Sub 

Else 

IbIDisplay.Text = IbIDisplay.Text & '"'." 
End If 
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(+) الجمع كود زر 


Private Sub bttnPlus_ Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
bttnPlus.Click 


Operand1 = Val(IlbIDisplay.Text) 
[Operator] = "+" 

clearDisplay = True 

End Sub 


کود(=) 


Private Sub bttn Equals Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttn Equals.Click 


Dim result As Double 
Operand2 = Val(IlbIlDisplay.Text) 
Try 

Select Case [Operator] 

Case "+" 

result = Operand1 + Operand2 
Case "-" 

result = Operand1 - Operand2 
Case '"*" 

result = Operand1 * Operand2 
Case "/" 

If Operand2 <> "0" Then IblIDisplay.Text = result 
End Select 

Catch exc As Exception 

Msg Box(exc.Message) 

result = "ERROR" 

Finally 

IbIDisplay.Text = result 
clearDisplay = True 

End Try 

End Sub 


(-) كود عملية الطرح 


Private Sub bttnMinus_ Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttnMinus.Click 


Operand1 = Val(lbIlDisplay.Text) 
[Operator] = "-" 
clearDisplay = True ' IbIDisplay. Text = 


End Sub 
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(*) كود عملية الضرب 


Private Sub bttnMultiply_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) 
Handles bttn Multiply.Click 


Operand1 = Val(IlbIDisplay.Text) 
[Operator] = '"*" 
clearDisplay = True 


End Sub 


(/) كود عملية القسمه 
Private Sub bttnDivide_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)‏ 
Handles bttn Divide.Click‏ 


Operand1 = Val(IlbIDisplay.Text) 
[Operator] = '"/" 
clearDisplay = True 


End Sub 


اكتب هذا الكود في ال _ه۲٥]‏ وغير الخاصية من 
Form_load gil form_keypress‏ 


Private Sub Form_KeyPress(ByVal sender As Object, ByVal e As 
System.Windows.Forms.KeyPressEventArgs) Handles MyBase.KeyPress 
If System.Char.IsDigit(e.KeyChar) Or e.KeyChar = "." Then 

If clearDisplay Then 

IbIDisplay.Texit = ''" 

clearDisplay = False 

End If 

IbIDisplay.Text = IbIDisplay.Text + e.KeyChar 

End If 

End Sub 


كود زر المسح في مربع النص)×٥۲.رهامء۱0iطا‏ 


Private Sub bttnClear Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles 
bttnClear.Click 


IbIDisplay.Text = 
End Sub 


أنتهى الدرس 


11۰ 
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EE Game 
[ Button 


i standard (O Advanced 


RadioButton2 ۱ 


| ۹ 
[f RadioButton ` 1 


Public Class Form1l 


Private Sub Button1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
If RadioButtonl. Checked = True Then 
a = 1 
Else 
a= 2 
End If 
Form2. Show () 
End Sub 


Private Sub Forml1 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
RadioButtonl. Checked = True 
Buttonl . Select () 
End Sub 
End Class 
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EE Game E BIE 


[ Butstart | ا‎ | 


| Butpress ا‎ 


f ibihits | 


Timerl Timer 


Public Class Form2 
Dim hits As Integer = 0 
Private Sub Form2 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
Me. Timerl.Enabled = False 
Me. Timer2.Enabled = False 
Me. Butpress.Enabled = False 
End Sub 


Private Sub Butstart Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Butstart.Click 
Select Case a 
Case 2 
Me. Timerl. Interval = 1000 
End Select 
Me. Timerl.Enabled = True 
Me. Timer2.Enabled = True 
Me. Butpress.Enabled = True 
Me. Butstart.Enabled = False 
End Sub 


Private Sub Butpress Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Butpress.Click 
hits = hits + 1 
Me. lblhits. Text = Format (hits, "Number of hits = # ") 
End Sub 


Private Sub Timer2 Tick (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Timer2. Tick 
Me. Timerl1l.Enabled = False 
Me. Timer2.Enabled = False 
Me. Butpress.Enabled = False 
Me. Butstart. Enabled = True 
End Sub 


Private Sub Timerl Tick (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Timerl. Tick 
Randomi ze () 
Me. Butpress.Left = 200 * Rnd() 
Me. Butpress.Top = 200 * Rnd() 
End Sub 
End Class 
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Date Calculator 


Date Lalculater TEK 


كيفية حساب الزمن بالثانية من أى تاريخ 


. [ Datetimepickerî j 
ListBox 1 | اسر‎ 
03 نوفمیر‎ 200 ¥ 
LIstbox 1 

Unit 
0 Days RadioDays | 
@ Halts Radiohours 
RadioMinutes : 


_ 
walculater 0 Radioseconds 


Public Class Form1l 
Dim a As Integer 
Dim d As Long 
Private Sub Radiodays CheckedChanged (ByVal sender As System.Object, ByVal e 
As System. EventArgs) Handles Radiodays. CheckedChanged 
a = 1 
End Sub 


Private Sub Radiohours CheckedChanged (ByVal sender As System.Object, ByVal e 
As System. EventArgs) Handles Radiohours. CheckedChanged 
a= 2 
End Sub 


Private Sub Radiominutes CheckedChanged (ByVal sender As System. Object, ByVal 
e As System.EventArgs) Handles Radiominutes. CheckedChanged 
a= 3 
End Sub 


Private Sub Radioseconds CheckedChanged (ByVal sender As System. Object, ByVal 
e As System.EventArgs) Handles Radioseconds. CheckedChanged 
a = 4 
End Sub 


Private Sub Buttonl1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
Select Case a 
Case 1 
d = DateDiff (DateInterval.Day, DateTimePickerl. Value, Now) 
ListBoxl. Items. Add ("the difference " & d & " Day") 
Case 2 
d = DateDiff (DatelInterval. Hour, DateTimePickerl. Value, Now. Date) 
ListBoxl. Items. Add ("the difference " &€ d &€ " Hour") 
Case 3 
d = DateDiff (DateInterval.Minute, DateTimePicker1l. Value, 
Now. Date) 
ListBoxl. Items. Add ("the difference " & d & " Minute'"') 
Case 4 
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d = DateDiff (DatelInterval. Second, DateTimePicker1l . Value, 
Now. Date) 
ListBoxl. Items. Add ("the difference " & d & " Second") 
End Select 
End Sub 


Private Sub Forml1 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
DateTimePickerl. ShowCheckBox = True 
Me.Text = "Date Calculater" 
Buttonl. Text = "Calculater" 
Radiodays. Checked = True 
Buttonl . Select () 
End Sub 
"Programming Mohamed Ahmed Youssef 
End Class 
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Multiplication Examiner 


كيفية تصميم جدول الضرب المتطور 


Hl Multiplication Examiner E 2 


| This application will help ¥ouı to learn mutiplication . 

| Standard level is used for 12*12 mulitiplication table. 

Moderate level i5 used For mulitiplication of 2Z digit numbers. | 
Advanced level is used for multiplication of 3 digit . | 


I Standard 
(J Moderate 


J Advanced 


Public Class Form1l 


Private Sub Button1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
If RadioButtonl1l. Checked = True Then 
a = 1 
ElseIf RadioButton2. Checked = True Then 
a = 2 
Else 
a = 3 
End If 
Form2. Show () 
End Sub 


Private Sub Forml1 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
Buttonl . Select () 
RadioButtonl. Checked = True 
End Sub 
End Class 
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Hl Multiplication Examiner 


| textboxa 
E E | 


| textbox | ETT TE 1 [submit | 


Plase Enter the Result 


ل 


[textbox3 | f Button2 ! New Yalue | 


Public Class Form2 
Dim nl, n2 As Integer 
Dim r1, r2 As Integer 
Private Sub Form2 Load (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles MyBase. Load 
Buttonl . Select () 
TextBox3. Text = "Plase Enter the Result" 
Select Case a 
Case 1 
Randomi ze () 
n1 = 1 + 10 * Rnd() 
n2 = 1 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy FEF COSEr(NnZ) LT 
TextBOox2. Text = '""" 
Case 2 
Randomi ze () 
n1 = 15 + 10 * Rnd() 
n2 = 15 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy "TF COSEI(NZ) 1T =< 
TextBOox2. Text = '""" 
Case 3 
Randomi ze () 
n1 = 100 + 10 * Rnd() 
n2 = 100 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy TT FT CESEE(NZ) FG TT >IT 
TextBOx2. Text = '""" 
End Select 
End Sub 


Private Sub Button2 Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button2.Click 
Buttonl . Select () 
TextBox3. Text = "Plase Enter the Result" 
Select Case a 
Case 1 
Randomi ze () 
n1 = 1 + 10 * Rnd() 
n2 = 1 + 10 * Rnd() 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy " Ff CSEE(NZ) FT =1 
TextBOx2. Text = '""" 
Case 2 
Randomi ze () 
n1 = 10 + 10 * Rnd() 
n2 = 10 + 10 * Rnd() 
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TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
Dy TF CESCEE(NZ) FG O >T 
TextBOx2. Text = '"" 
Case 3 
Randomi ze () 
n1 = 100 + 10 Rnd () 
n2 = 100 + 10 Rnd () 
TextBoxl. Text = "The Result of multiplication " + CStr (n1) + " 
by " + CStr(n2) + " = " 
TextBOx2. Text = '"""' 
End Select 
End Sub 


Private Sub Button1l Click (ByVal sender As System.Object, ByVal e As 
System. EventArgs) Handles Button1l.Click 
r1 = n1 * n2 
Try 
r2 = TextBOox2. Text 
If r1 = r2 Then 


TextBox3. Text = "congratulation , True Result" 
Else 
TextBox3. Text = "Sorry ,Wronge Result the True Resulte " + 
CSEE(EI) FET 
End If 


Catch ex As Exception 
MsgBox ("Enter the answer") 
Exit Sub 
End Try 
End Sub 
End Class 
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كيفية تصميم أختبار خاص بأعلام الدول‎ 


۱۹1۸ 
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الجزء الخامس التعامل مع قواعد البيانات‎ 


SQL Server 2005 چمliرڊ شرح‎ 


اقدم لكم سلسة من دروس فيجوال بيسك ٠٠٠٠١‏ و 5012005 للمبتدئين 

بداية اتناول في هذه السلسلة بعض المواضيع المهمة ولا اتطرق كثيرا في شرح المغيرات والمصفوفات والعمليات الحسابية 
وانما امر عليها سريعا. 

واعتمد في دروسي على التطبيقات حيث يتم عرض التطبيق وخطوات عمل التطبيق وفي النهاية تحميل التطبيق للتدريب عليه . 


اما الدروس فتنقسم الى قسمين 

أ- قسم خاص بلغة الاستعلام 5Q1‏ 
ويحتوي : 

54۵12005 تحمیل برنامج‎ -١ 


SQL Server Management Studio Express 


http ://msdn.microsoft.com/en-us/express/bb410792.aspxX 
http ://qao.microsoft.com/fwlink/?Linkld=65110 
تحمیل‎ 5Q@1L2005_Service_Manager 


http ://moonfiles.com/in/upload/wh 18943946.zip 


۳- المدخل الى2005ا5۵ 

northwnd - PUB تٽlنlıڊ تحميل قاعدة‎ -٤ 

-٥‏ طريقة استيراد قواعد بيانات جاهزة. 

-٦‏ طريقة استيراد ملفات النسخ الاحتياطية م ں )ھ8 
۷- طريقة انشاء ۷٥W‏ 


Select Statment ga Jalaتll‎ -۸ 


اولا : 
مفهوم ا5۵ 
يرمز اختصار 5۵1 إلى ""لغه الاستعلام اıniكأiأ'' Language Structured Query‏ 


إن لغة 5Q1‏ هي بسيطة نسبياًء ولكنها فعالة للغايةء فالكثير من التعليمات البسيطة في هذه اللغة تخفي ورائها خصائص فعالة 
يمكن استخدامها للقيام بالعديد من العمليات المعقدة المعروفة في قواعد المعطيات . 


ثانيا : 

الفرق بين اه8 و Access‏ 

كثير منا يسأل الفرق بين قاعدة بيlنات Microsoft Access gy SQL‏ . 
سوف نتناول بعض الفروقات بین S4)‏ و sومA‏ 


Access : gl 
: ايجابیاته‎ 


سهل الإاستخدام 
رخيص الثمن 

توكر الدعم الفني . 
یدعم نمادج (وہإہ۴ ) 
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سلبیات : 

الامان : ضعيف الامان بحيث يسهل سرقته واختراقه 

الحجم : يتحمل حتى ۲ جيجا 

عدد المستخدمین : ۲٠١‏ مما يسبب الضغط على محرکات نظام ( ٤ل‏ ؟هSما‏ ما ) مما تسبب تلف للبيانات . 


S1 : ثانيا‎ 

الامان : نظام الامان عالي جدا 

الحجم : یتحمل حتی ۱ تیرا بایت 

عدد المستخدمين : لا يوجد عدد محدد 

يدعم خاصية الوظائف المعرفة مسبقا sمurںلمءهإ۲ 51٥١٠١4‏ و الترجرز ء۲٠‏ ووا۲۲ والتي نتطرق اليها في الدروس القادمة 


Microsoft Access y SQL jıب هذه بعض الفروق‎ 


اولا : تحميل البرامج : 
SQL service manager‏ 
يمكنك تحميل البرنامج من الرابط التالي : 
لنظام التشغیلم× sسowلإWin‏ : 
http ://www.sqldbatips.com/samples/code/SQL2005SCM/SQL2005 Service Manager.zip‏ 
لنظام التشغيلهاو¡ا : 
http ://www.sqldbatips.com/samples/code/SQL2005SCM/SQL2005 Service Manager Vista.zi‏ 


بعد تحميل البرنامج يظهر البرنامج في شريط المهام 


aE - 


TF 11:20‏ ا ۳ E Em‏ 
انقر نقرتين على البرنامج فيظهر لك كما في الصورة 


0 SQL Server Service Manager ك‎ ! 
SERYEN: اس الس یر‎ 


TEYICES: SAL TERYEN ¥ | 


Refresh 2ervICEez... 


SQL Server Management Studio Expresslilû 


1۰ 
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: تحميل البرنامج‎ 


http ://www.microsoft.com/downloads/details.aspx?FamilyID=c243a5ae-4bd1-4e3d-94b8- 


DaOf62bf7796&displaylanag=en 
http ://msdn.microsoft.com/en-us/express/bb410792.aspX 


( Start --- programs---- microsoft sq|2005 ) لفتح البرنامج انقر على‎ 


۹ Location: Z1 Pragrarn Files ic 
0 set Program Access and Defaults Server\ 901 Tools Bini 55helll 


Windows Catalog 


3 Microsoft Office 
: ln Microsoft Office Gutlook, Laonnectûr ٣٤ 
Loanfiguratian Tools 


r Microsoft SQL SerYEr ZOOS 


| ا‎ E م‎ ls Microsoft SQL SerYEr 


ا 
settings ۴‏ # 


2 Search ۴ 


1 * SL Server Management Studig Express 


0 Help and Support 


Windows XP Professional 


Shut Down... tammailinboxLightraspx?n=B487447 12, ۳‏ 0 
عند الدخول على البرنامج تظهر لك النافذة الاتية : 


Connect to Server‏ 8چ 


Microsoft ا‎ Windows Server System 


SQL Server 2005 
SEF YE ype! | Database Enıgirıg: اا‎ | 


SEFYEF NAE: 


authentication: | windows authentication 


Eerîerr ber: passa û 


حيث في خانة ممرآ مه5 يترك كما هو الا اذا كان لديك اكثر من سيرفر يمكنك اختيار السيرفر المحدد من هذه الخانة 


Prog : Mohamed Youssef 


Name‏ verام5يكتب‏ فيه اسم السيرفر ( اسم الكمبيوتر ) ولمعرفة اسم السيرفر 
انقر نقرتين على ايقونة موهمج" ءء مء 541 الموجودة في شريط المهام 
فيظهر البرنامج كما في الصورة 


SERWET: 


TENYICES:; 


فاسم السيرفر موجود في خانه م۷إم5 
اما الخانة الثالثة Auth) cat 0٣‏ : فلھا خیارین 


أ : Windows Authentication‏ -دخول البرنامج دون الحاجة الى اسم المستخدم والرقم السري 
ب : Server Authentication‏ اSQ‏ -دخول البرنام باسم المستخدم والرقم السري ويتم تحديده عند تنصيب البرنامج. 
زر : أConnec‏ الاتصال ب SQL‏ 


ء۶ « 


انتهى الدرس الثالث وسوف نبدأً في الدرس القادم باذن الله بالتطبيقات على 5۵12005 


الد رس الرابع : شرح شاش Object Explorer‏ : 


يحتوي Ni‌roso† S۵1 Sever‏ على شاشتین 
أ Object Explorer‏ -من الجهة اليسرى 
تضم هذه الشاشة مزود مرتبي غلى سبيل المثال ( قواعد البيانات - جداول - حقول - سرية النظام ( ... 
كما في الشكل 
ب : yاaصصںS‏ ۔الجھة الیمنی 
نلاحظ تحت السيرفر الخاص بالجهاز توجد مجموعات من الاجهزة المركزية حيث تنقسم هذه الاجهزة الى اربعة اقسام نذكرها 
بشيئ من التفصيل 
Databases gl‏ : 
aystem Databases‏ = 


Hl ازا‎ raster 
3 ازا‎ rıodel 


3 ازا‎ msdb 
Fl | J| tempdb 


a | badar 
# ReportseryertEadar_SOL 


FH | ¥ Report5erver$Badar_SQLTermpDE 
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ويحتوي جميع قواعد البيانات المخزنة في البرنامج ويحتوي كذلك ثلاث قواعد بيانات اساسية حيث لا يستطيع النظام العمل 
بدونها وهي : 


أ : Database Master‏ -وهي قاعدة البيانات التي يتم تخزين جميع قواعد البيانات فيها 
ب : املN0‏ مasطهtهD‏ -وهي قاعدة بيانات التي تحتوي الشكل الاول لقاعدة بيانات. 
ج : Database rempdb‏ -وهي قاعدة بیانات موؤقته . 


ثانیا : راا هم5 : ويحتوي على الكائنات المسئولة عن حماية قواعد البيانات وتوزيع الصلاحيات . وينقسم الى ثلاثة اقسام ‏ 
FF SECUFIEY‏ 1 


E A Loains 
E J Server Roles 


[O tredentials 


ا : روا -يحتوي على مستخدمي قاعدة البيانات وكلمات السر الخاصة بهم . 
ب : مامR‏ ۲مإمS-المستخدمين‏ منقسمين الى مجموعات . 


Managment gy : Server Object ÛÛ 
وهي ادارة قواعد البيانات . وتحتوي على‎ 
. أ : مu)مaط -النسخ الاحطياتية لقاعدة البيانات‎ 


ب : Linked Server‏ -ويحتوي على المحرکاٽ ) Provider‏ ( 
ج : Maintenance Plans‏ -يحتوي على مخططات صيانة قواعد البيانات . 


انتھی الدرس الرابع 


انشاء قاعدة بيانات : 


في هذا الدرس سوف ننشيئ قاعدة بيانات جديدة باسم Emp_iİnfo‏ 
ويحتوي على الحقوJ ID - Name - Address - Gender - Country - Birthday lll‏ : 


لانشاء قاعدة بيانات جديدة انقر بالزر الايمن على وموھطجاھD‏ ثم اختر New Databases‏ 
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Attach... 


Restore Database! ™.. 2 


Restore Files and FilEqroUps... 


Reports 


Refresh 


في خانة : 2me‏ مasطهاه‏ نكتب اسم قاعدة البيانات ثم نضغط على زر )0 


SEE] 


2 aCFipE F” 


13 Help 


نكتب اسم فاعدة البيانات المراد الشانها Database name:‏ 


CminEF | zdefaull x 


|_| Use Full-text indexing 


Database Files: 


Logical Hame | File Type  Filearoup Initial Size IME] Autogrowth 
Data PRIMARY 3 BY 1 ME, unrestricted growth 
_1 Lag Not Applicable 1 BY 10U percent, unrestricted fû... 
اا‎ ; 


كما نلاحظ تم اضافة قاعدة البيانات الجديدة 


«» 0 


1٤ 
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JALADASES‏ اګ 
E I System Databases‏ 
Database Snapshots‏ 
badar‏ آ E2‏ 
F || ReportServer$Badar_SQL‏ 
Hl ReportSeryer$Badar_SHL TermpDE‏ 
E I Emp_infn‏ 
Fi [A CGatabase Diagrams‏ 
HF LD Tables‏ 
Fl J views‏ 
A CD Synonyms‏ 
CD Programrmability‏ | 
Fl [O storage‏ 
Fl [O Security‏ 


انشاء جدول جدید 
لانشاء جدول جديد لقاعدة البيانات الزر الايمن على وماطج۲ ثم اختروماطج۲ New‏ 


. ۲ Ernp_infa 
3 Catabase Diagrams 


Filter 
Reports 


O Security Refresh 
[I Server DbIETEE 


الان نقوم بادراج الحقول المذكورة في الإعلى 2 خColumnNameil‏ 


_olumn Name Data Type 5اا بدا‎ 

IÛ nchart10)} 
JariE nchart 10) 
Adderss nchart10)} 
tender nchart10)} 
_ontry nchart10)} 
: ncharf 10} 


افك 


في خانة همر هه نختار نوع البيان وطبعا في درسنا نختار النوع الافتراضي 
اما انواع البيانات فسوف اشرحها بشيئ من التفصيل : 


النوع : "| يأخذ أرقام صحيحة سالب أو موجب وتکون بین - ۲٠٤۷۰٤۸۳۰٦٤۸‏ حتي ۷١٤٦۸۳۰٤۷۰٤٠ء۲‏ 
وياخذ حيز في القرص حجمه ٤٠‏ بايت. 


1° 


Prog : Mohamed Youssef 


-النوع : Bigint‏ مثل النوع النوع Int‏ لکن حجمه أكبر ويقبل من — TTPFPTVYTOTTCAoeftNVoecAN‘sA‏ حتی 
77,7 ,9,223,372,030 
ویاخذ حیز ۸ بایت. 


-النوع : ٣۲‏ اا2" یقبل 32,768 - حتی الرقم ۳۲۰۷٦۷‏ 
ه ‏ حجمه ۲ بایت . 


-النوع : اہارہاآ یقبل من ۰ حتی ۲٠٥١‏ - حجمهھ ۱ بایت۔ 
النوع : ها٥‏ يعني حرف › وهو عبارة عن نوع يجعل حقل البيانات يتقبل عدد معين من الحروف من ١‏ إلى ۸٠٠٠١‏ حرف 


-النوع : وط يأخذ حروف ولكن حروف من النوع ملهءامل أي يمكن تخزين كل اللغات وليست اللغة الإنجليزية فقط وهو 
يتحمل من ۱ إلى 0T‏ 


-النوع : طج۷ يأخذ من ١‏ إلى ۸٠٠٠١‏ حرف - لكن حجمه بخلاف الأنواع السابقة غير ثابت حيث يكون حجمه حسب عدد 
الحروف التي فيها 

-النوع : ×2٣٠)۸2۲ءا۷a)‏ مثل جج۷ يأخذ ۸٠ ٠٠‏ حرف حيث يكون حجمه حسب عدد الحروف التي فيه. 

النوع : a2۲‏ نفس : مثل ع۷ لكن ياخد حروف ملهءاہل ولذلك هو يقبل ٠٠٠٠۰‏ حرف 

(Varchar(max Egil Jû (Nvarchar(max : عgill-‎ 


-النوع : **** وهو يأخذ عدد حروف حتی ۲ جيجا بايت 
لكن من الخطاً فعل ذلك - فتخزين مثل هذا الحجم داخل خلية حقل واحد مع الاستخدام سيكون هناك بطئ فى القراءة 


-النوع : N****‏ مثل النوع **** لكن يخزن الحروف ك مإهءاہ U‏ 


-النوع : موهص| مثل النوع **** لكن نظام التخزين بيكون رهہ 8i‏ طبعاً نحن نستخدمه مع الصور وملفات الصوف وخلافه 
من امور المالتميديا 


هذه انواع البيانات 
الان نضع المفتاح الاساسي للجدول وذلك بالزر الايمن على اول حقل (١(‏ ومن ثم اختيار صورة linllح (Set Primary Key‏ 
) 
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Lolumn Hame Data E ET Hullz 
i Insert Column 7 
1F Delete Column 1 
3 Relationships... ا‎ 
El IndexesfKeys... 
> Fulltext Index... L 


ML Indexes, ,, 


heck Constraints... 
a menerate Zhange Script... | 


لفتح الجدول نضغض بالزر الايمن على الجدول المراد فتحه ومن ثمءاطة7 ٣مpمO‏ 


= 4 Ermp_info 
IF [A Catabase Diagrams 
3 [I Tables 
[F ق‎ awstem Tables 
+ اعا‎ Ey Table, 
EH | Edit 
H [a rou 
aH <torz BE 
E A Secu | OpenTable | OpenTable 
i Security acripEt Tablê a5 / 
A Server Chie 
النتيجة‎ 
| 10 EE Adderss ender Lountry Birthday 
F badar rstak 1 aran 1111980 
2 nabil FYI 1 orîanl 1121385 
3 fatma rmıscak F arman 2151974 
4 salir armerak 1 aE 111382 
ِ 5ala ۴4i F aE I125 
1. اد5‎ sêEeb F 2q4¥pk AES 
۳ khalid sahar 1 arian 351380 
3 E seEb F 2qY¥pk EN 
*# ULL ULL ULL UL UL UN 


الان عليكم تملية الخانات بالبيانات تمهيدا للدرس القادم 
انتھی الدرس الخامس 
سوف نتناول في الدرس القادم باذن الله اوامر ا5 


الدرس السادس 
سوف نتناول في هذا الدرس عبارت او معامل 1ا5 


Prog : Mohamed Youssef 
New Query اولا : نضغط علی‎ 


Fila Edt Yiew Tools Window Lommunity Help 


EET REESE EEEELE 


فتظهر لنا نافذة الاستعلام 
من خانة قواعد البيانات نختار قاعدة البيانات التي تستخرج منها البيانات 


Dbjert Explorer Bada, 
Erip inû 


pubs 
ReportServertBadar_SHL 
RepoartSeryertBadar_SHLTermpDE 
db 


الان نكتب الكود في شاشة الاستعلام : 


اولا : القاعدة العامة :لاستخدام الاستعلام تتكون من كلمتين ( †ءم‌امS‏ ) و ( ۴۲٥۳‏ ) 
فمتلا : اذا اردنا اظهار بیانات الoجدول‏ ٥٤ہ¡‏ _ م٣٤‏ نكتب الصيغة التالية 

1- Select 

-2اسم او اسماء الحقول 

3- From 

-4اسم الجدول. 


بعد كتابة الصيغة نضغط على مأںcم×xع‏ 
فتكون الصيغة كالاتي : 


From Emp_ info‏ * ectاSeحیٹث‏ ان * تدل علی جمیع الحقول ۔ 
فتكون الصورة كالاتي : 


Prog : Mohamed Youssef 


CAEL E 


| MOEB3781391B...QLQuery2.sql* Summary | 
| aE EE ak ERLE O aR Emp info 


+ 


| J Results Ê Messages | 
| I0 Hame  Adderss Gender Country | Birthday 


1 1 badar muscat M oman. 1#11980 
2 2 nmabl nwî M oman 112/1985 
£ 3 fatma muzacaly, F 7ے‎ A TA ERE 
| 4 4 salm  ameral Î, ا‎ E 111982 
3 D1 salma ruwl F FE A HEH 
|8 KE salla seeb F 2gpp! RFS EHS 
۶آ‎ f khald sohar 1 amarî ETS El 
3 3 sala seeb F EqHp! MULL 


- 2اختيار حقول معينة من الجدول فئیكنcouniryjù‏ - name - address‏ 
Select Name ,Adderss ,country From Emp_info‏ 
فتکون النتيجة کما في الصورة 


یس 


اسو سوہ بدت 


B...QLQuery2.sql™ summary | 


Belect Name „, AAdHer3s „country From Emp I1ntlo 


ا 


ا 
Î Results 1 33 Messages |‏ | 


armê ûdderzs cau 


1 i badar ; muscal oman 
2ا‎ rabil ruwi oral 
2 fatma muscal oman ا‎ 1 
4ا‎ salm ameral uae نة‎ ! 
جو ج‎ 
| 5 salma HMI aE 
EB salla šeeb 2qHp! 
ا‎ # khald sohar omar 
8 salya seeb egypl 


DISTINCT عبر‎ -۳ 

هذه الجملة المقصود بها اظهار البيانات بدون تكرار 

فمثلا في حقل راه توجد بعض الدول متكررة فاذا اردنا اظهار البيانات الموجودة في حفل راہ ه٥‏ دون اظهار الدول 
المكررة نكتب الكود التالي : 


Select DISTINCT Country From Emp_info 


Prog : Mohamed Youssef 


النتيجة 


% 


i Results E2 


Country 


همه فلح لطا كط ا ن لد ب 
e‏ 
Û‏ 
1 


38ا 


Where ةرlبع‎ - < 


والمقصود به اذا اردنا اظهار كلمة معينة من حقل او القاعدة 
مثال : نرید اظهار اسم لiاجھ»×‏ من حقل ٥ہa×‏ 

فتكون لصيغة كالاتي : 

Select * From Emp_info 

Where Name = 'Khalid" 

**نلاحظ اسم هiاه»‏ بين علامتي تنصيص' iاة!»‏ ' 


meEleEZCTE * From Emp Info 
Where Name = 'Ehalid' 


% 


Î Results a Messages| Û 
IM Hane ÃAdderss | Bender Lournty Birthday 


1 iF khald soha MI aman 3/821 980 


mamannnnnn 


علما انه يمكننا استخدام المعاملات التالية اثناء استخدام عبارة مما 
=تساوي 


۰ 


Prog : Mohamed Youssef 
لا تساوي‎ >< 
>اکبر من‎ 
<اصعر من‎ 
>اکبر من او تساوي‎ 
<=اصعر من او تساوي‎ 
8شرط بین قیمتین‎ ewe 
م#اللبحث عن كلمة مشابهة‎ 


Order ByةرlڊE5-‎ 

والمقصود به الترتيب حسب حقل معين 

مثال : نرید عمل استعلام حسب ترتیب ول۸ 
الصيغة . 

Select * from Emp_info 

order by Adderss 


فتكون النتيجة كالاتي : 


ElLEZT *" ITrom Emp Into 


2EdeEr py AAferas3 


2 
| E Results | î messages|________ 
|_1 ID | Name [Adderss | Gender | Country | Birthday 
1 i4 salm | amerat ÎM aê 14۸982 
ن‎ 1 badar | muscat | M omar HEE 
ك‎ 3 fatma j muscatl | F amar AHA ES 
|4 2 اسب | اقم‎ 1 amarî 1121985 
5 BS salma j WI F۴ El EARNERS 
|5 E zaãlda ڼ‎ seEb F Egypt TR EHS 
1 3 salma | seeb F 2qrp! MULL 
| 3 f khalid j sohar 1 amarî dF 18U 


Or و‎ Ad المعاملین‎ -٦ 

تستخدم للربط في شرطين او اكثر 

-معامل هم۸ : يقوم باستعراض النتانج في حال تحقق جميع الشروط 

-معامل 0۲ : يقوم باستعراض النتانج في حال تحقق شرط اي شرط من الشروط . 


: A۸ مثال علی معامل‎ 
Select * From Emp_info 
Where Adderss ='muscat' 
and Country='oman' 


1۳۱۹ 


Prog : Mohamed Youssef 


ıeEleEZCE * From Emp _ Inia 


LAAPESZS ='rmusazcat أ‎ 


1% 


lj Messages | 


1E Hame Adderss | Gender Lounty Birthday 


1 1 badar muscal MM oman EE 


tama muscal F omaãlî A aT EE‏ 31 ت 


Select * From Emp_info 
Where Name ='salim' 
or Country='egYypt' 
النتيجة‎ 


eEleEZTE * From Emp Info 
Where Name ='szalim' 
OE LOUNTEY=' ETpT 


Ê Messages | 
IOC Hame Adderss: Gender Lounty Birthday 


1 :#4 i salm. ameratl M FEE 1171382 
[E šaldlã seeb F EqHp! FS EHS 
3 sala seeb F۴ aqypt MILL 


هذه بعض عبارات ومعامل ال ا5 
في الدرس القادم سوف نستكمل مع عبارIت‏ ) (IN - Between - Alis - Like‏ 


اولا : معامل : Count‏ 
يعمل هذا المعامل لحساب عدد الحقول . 
مثال : 


نرید ان نعرف عدد حقول جدول ٥ہ¡‏ _م٣۴‏ 


فتكت 
Select Count(*) From Emp_info‏ 


۳۲ 


Prog : Mohamed Youssef 


ثانيا : معامل |١‏ هو عبارة عن اظهار بيانات معينة من حقل معين 
مڎJl‏ : Emp_info Select * From‏ 
("Country IN(oman','uae where‏ 


ثالثا - 


Between 

عبارة عن اظهار بيانات بين قيمتين 

هذه لن يتم شرحها ولكن ارجوا التجريب 
في حال وجود اي صعوبة ارجو ابلاغي . 
القاعدة 

Select 

اسم الحقل او الحقول 

From 

اسم الجدول 

Where 

اسم الحقل 

Between 

١ قبمة‎ 


ارجو التجريب وابرغي بالنتائج . 


التعامل مع اكثر من جدول وربط الجداول 

في البداية نقوم بانشاء جدول جديد ( راجع الدروس السابقة ( 
واحفظه بالاسم الذي تربد 

الان ادرج الحقول التالية في الجدول الجديد 

ID 

JobName 

ContractT ype 

selary 


بعد انشاء الجدول واضافة الحقول المطلوبة جاء دور الربط بين الجدولين 
اضغط بالزر الايjn New DataBase Diagramsرتخا lkدzڊ DataBase Diagrams JiİE‏ 


2 | J Emp_infa 


Daka base Diaqr aa‏ ا 
a FO Tables Hew Database Diagram |‏ 
E CG views : |‏ 
E LD Synonyms E‏ 
Progr armrnability Reports :‏ تا #1[ 
ll [_ J Storage‏ 
E CG Security Refresh‏ 


A IO Morthwind 


الان نضيف الجداول المراد ربطها 


۳۳ 


Prog : Mohamed Youssef 


Add Table 


Tables 


Jabinfa 


الان نقوم بسحب د1 من جدول ٠ہام‏ "ع الى | للجدول الجديد الذي انشاءته 
فيصبح الشكل 


Emp_info 


JarmE 


Adderss 


JoblarnEe 


_oantractT ype 
ener #P 


sElEry 


_OUNEFY 
Birthday 


بعدها نضغط على زر حفظ ونحفظ العلاقة باسم معين 
بكذا تم عمل العلاقة بين الجدولين 


الدرس القادم باذن الله تعالي سيكون في كيفية جلب قاعدة بيانات موجودة سابقا وطريقة عمل النسخة الاحتياطية ملا»ءه6B‏ وطريقة تحميل ال 
BackUp‏ 


في هذا الدرس سوف نتناول كيفية ادراج قواعد بيانات جاهزة وكيفية عمل النسخ الاحتیاطیۂ c)upھB‏ 


للعلم امتداد ملفات 541 تكون بهينة 0۴ا 


سوف اعرض برنامج فيه ملفات الاس کيو (Pub - North Wind ) ll) J|‏ 
يمكنكم تحمليل البرنامج من الوصلة التالية : 


http ://rapidshare.com/files/120104132/SQL2000SampleDb.rar.html 


۳٤ 


Prog : Mohamed Youssef 
ثانيا : تنصيب البرنامج‎ 


بعد فك الملف نقوم بتنصيب البرنامج 


Microsoft SQL Server 200Û Sample Database Scrip1s‏ ا 


Installing Microsolt SHL Seryer 200Û Sample 
Database serIpîs 


Microsoft SAL SEerYEr AUN Sample Uatabase scripts |3 beliq Installed. 


.anczel Previous 


نجد الملفات في القرص سي ( ٥‏ ) 


* O instnwnd ١ ™ ا‎ : 


Zl. Microsoft SQL Server Query File : ١ قات‎ E 
2, Db KÊ ت الان کيو‎ 


NOR THYTID 
SL Serrer Database Transal,.. 
1,124 EB 


— | PUBS_LS 
SQL Server Database Transac, 
Fé EB 


١ 
l SR Server Database Frimaty 1. 
1, ZU EB 


=| MORTHAWYRND 
A SL Server Database PrtimafY 1:: 
ر2‎ 8 


ثالثاً : ادراج الملفات 


بعد ان نفتح برنامج 5۵12005 


5a†هطمءوعىلع نضغط بالزر الايمن‎ -١ 
attach بعد ھا نختار‎ -۲ 


۳° 


Prog : Mohamed Youssef 
Eject Explorer 


EF 


3 


E I SE 5 
2 Rep E 
۳ | Restore Database... 


Restore Files and FileqroUps,.. 
EHeporks 


Refresh 


۳- بعدها تظهر شاشة لاضافة قواعد البيانات نختار ل١ك۸‏ 


Script F7 Help‏ کک 


Databases to attach: 
MOF Fila Locatlûfi . Uatabašeê... | ږ_Ilach 43ۉ‎ Liner Stalls MEzzaãqE 


Rêye 


Latabase details: 


) ٥ ( الان نختار ملف قاعدة البيانات الموجود في القرص الحلي‎ -٤ 
Northwind تlنlيب ملاحظة . ي مثالنا اخترنا قاعدة‎ 


۳٦ 


Prog : Mohamed Youssef 


Attach Databases‏ ا 


Select a page r BE 


2 ceneral 


Latabases Eo attach: 


Attach A3 impr talus Message 
PHarthmirnd MOE... 


| RemayE 


Lurrent File Fath MEzsaqE 


Connertian. E-- ع‎ LASAL Serwer ZODO 5a... RR 
CHSAL Server 200Û 5a... ۳ 


"Northird" database details: - 


SerYEr: 


L_ûnnecktion: 
MESSI A Arninistrator 


wiew connection properktigs‏ پت 
Progress‏ 
Ready‏ 


REE 


O ES ES 


-٥‏ النتيجه 


1۳۴۷ 


Prog : Mohamed Youssef 


Object Explorer 


۲ = د ج 
SQL Server 3,0,1339 - MOEE378 133A Aministrator}‏ . ا 3 
EE Uatabases‏ 
E [A SYstem Databases‏ 
Database Snapshots‏ 3 
J MNMorthmind‏ =[ 
E A OGatabase Diagrams‏ 
E A Tables‏ 
E O System Tables‏ 
HEH Î dbo.Zategories‏ 
HE ÛÎ dba. Customer ZustarmerDerna‏ 
FH Û dbo, ZustomerDernoaraphics‏ 
EH Î dba. Lustomers‏ 
FH Û dbo.Ermplayees‏ 
EH Û dbo.EmplayeeTerritories‏ 
HEH Î dbo. order Details‏ 
FH I dbo. orders‏ 
FH Î dbo.Praducts‏ 
FH ÛÎ dba.Region‏ 
EH Û dbo. Shippers‏ 
FH ÛÎ dboa.Suppliers‏ 
FE ÛÎ dbo. Territories‏ 
HA J Yiews‏ 
Hl SYnONYrS‏ 
Hl Progr amrnabiliky‏ 
Hl Storage‏ 
Hl Security‏ 


الدرس التاسع 
طريقة عمل نسخۂ احتیاطیۂ Bac) up‏ 
-١‏ نضغط بالزر الايمن على قاعدة البيانات المراد عمل نسخة لها 


a 9 MT 
E N Lat FS 
H iA Tak 
E LA ie 
2 STIL 
3 prof Taek. 


ıl jı س‎ 

3 TEL Reports Shrink 
Security 
Server Obje Rename 
Replication Delete | Restore 


ManagêrnEer 
Refresh enerakte Scripts... 


Properties 


-١‏ تظهر لنا شاشة تخبرنا مكان حفظ الملف 


۴۸ 


Northwind-Full Catabase Backup 


§ ذا اردنا تفر مقان 


على 


۳- النتيجة 


Prog : Mohamed Youssef 


F Back Llp Database - Nortmwın d 


23 Script ” Help 


select a page 


SDUFCE 
Database: 
Recoyvery rodel: 
Backup type: 
Backup component: 
(®) Database 
Files and FIEAFOLUpS: 
Backup sek 
JamE: 
Gescription: 


Backup sek wil expire: 


(® After: 


Caonnêctiûn 2َ O an: 


îEerYEFr: CLEestinaktian 


Back. up to: 
_anneckian: 


MOES3781331 Administrator 


Yiew connection properties‏ پل 


ProgrFess 


O sx r € 0 a search Ey Folders EBÊ 


طريقة استرجاع النسخة الاحتياطية . 


Address (Oj CHAProgram Files\Microsoft SOL Server MSSAL.SMSSALBarckup 


File and Folder Tasks 


Other Places 


في الدرس السابق تعلمنا كيفية عمل النسخة الاحتياطية لقاعدة بيانات معينة وقلنا ان الملف موجود في مسار معين 


۳۹ 


E r ج‎ 7 a search 5 Folders ERÊ 


Address (Oj CAProgram Files\Microsoft SOL Server MSSAL.SMSSALBarckup 


_ 1 Northwind, bak 


Bûk Filê wy 
e, E 


File and Folder Tasks ا‎ 


Other Places 


في هذا الدرس سوف نتناول كيفية استرجاع النسخة الاحتياطية . 
-١‏ الخطوة الاولى يمكنك استخدام احدى الطريقتين وكلاهما صحيح 


-يمكن انشاء قاعدة بيانات جديدة وتسمستها باسم معين 
-النقر بالزر الايمن على Database‏ وهذە الطريقه التي نسنخدمها في درسنا 


11 


Je Dat ab 


Restore Database... 


` Restore Files and FilegroUps,;. 
Reports 
Refresh 
تظهر لنا شاشة جلب قاعدة البيانات‎ ۲ 

کې خانة : Database‏ 0 نکتب اسم القاعدة البيانات ) كقاعدة بيانات جديدة ( 

في القسم الثاني من الشاشة From Device jlii‏ أجلْب قاعدة البيانات من القرص المحلي 
-الان نختار زر استعراضص 


۳- في هذه الشاسة نختار زرهىل۸ 


1۰ 


Prog : Mohamed Youssef 


Prog : Mohamed Youssef 


> الان نقوم باختيار النسخة الاحتياطية من القرص او المكان الذي تم تخزينه فيه . 


Prog : Mohamed Youssef 


'' Locate Backup File - MOEB378199 


zelact the File: 


H-G MetaProducts Inquiry 
HO Microsoft ActiveSync 
HO Microsoft Analysis Services 
3 1 Microsoft ZAPICOM 2,1,02 
HD Microsoft Gevice Ermulatar 
HD microsoft frontpage 
HTN Microsoft Office 
HEN Microsoft Office Outlook Connector 
A TD Microsoft SAL Server 
` ا ك‎ 0 

a 20 

a I MSSAL 

a I MSSAL.1 

OD MSSAL,2 

HD MSSAL.3 

HD MSSAL.4 

a  M5SAL.5 

E- MAL 
a GER 
٠ 1 OF Northwind, bak. 

E INT 
H- Data 
E H FTData 
H1 OB Install 
HI 1085 


selected path: 


Files of type: 


File narnEë: 


©) الخطوة الاخيرة نلاحظ وجود قاعدة البیانات نختار زر‎ ٥ 


Prog : Mohamed Youssef 


IT UNI 


f srript ” 


- × 


Destination For restore 


Select or type the name of a new or existing database For Your restore operation, 


To database: |moeforurm ېه‎ 


Toa a point in kime: Mast recent possible | = 


Source For restore 


Specify the source and location of backup seks Eo restore, 


J Fram database! 


(@) From device: cr Program Files\Microsoft oL zerverM55OL.SIMSSOL" 
| 


Select the backup sets to restore: 


[Bj 3L 


E ۳ . {SQL Server 9.0.1399 1 _ _ Jfadministrator) 


Databases : 


El 


Zl | | moeforurn 
FF I Database Diagrams 

E [O Tables 

I 3Ystem Tables 

Î dbo. Categories 

I dbo. Customer ZustormerDerno 
I dbo, ZustomerDermographics 
Î dbo. Customers 

E dbo.Employees 

EI dbo.EmployeeTerritories 

Î dbo. order Details 

I dbo. orders 

E dbo.Pradurcts 

Î dbo.Region 

Î dbo. Shippers 

Î dbo. Suppliers 

I dbo. Territories 


HERR RERERREEERERE 


ا الدرس القادم سوف نتطرق الى كيفية التعامل مةخ Views‏ 


Prog : Mohamed Youssef 


الدرس العاشر وسما۷ا: 


مشاهد البيانات أو Vis‏ تشبه کثیراً استعلامات الأكسسر Query‏ ( 
وهي تستخدم للعرض من عدة جداول كما نلاحظ في درسنا 

الفائدة من المشاهد 

طبعاً الفائدة الكبيرة منه التحكم بصلاحيات الوصول) لتحديد الحقول المسموح برؤيتها مثلاً لهذا المستخدم أو ذاك(.. 
في درسنا سوف ننشئ مشاهد ( سه۷ ) ونضيف فيه البيانات الاتية 
جدوJ‏ | Customers‏ : 

: CompanyName -- ContactNameJgقحئl‎ 

جدول؟ 6sل0‏ : 

: OrderDateJgقحئl‎ 

: [Order Details] "أlودج‎ 

: UnitPrice --- Quantity --- Discount Jgقحئنiا‎ 


*انشاء ۷W‏ جدید 
نضغط بالزر الايمن على sسما۷‏ كما في الشكل 


EES 
3 | Northwind 
FF O Catabase Diagrams 


FA O Tables 
3 i س‎ 
EE 
E Og Pr | 
Filter ء‎ 
a i 
_ دا لقا‎ E 
1 O Security 
1 erer GÛ Refresh 
1 O FReplicatio 


ثم نختار wمVi New‏ 
في الشكل التالي يظهر لنا مريع نضيف الجداول المناسبة 
Add [able‏ 


LalEqOrİES 

_USEomer_ustaomerDEermn 

_ustomerDernographics 

_USEOMES 

Ernployees 

ErmployeeTerritories 

irder Details + 1 ١ َة‎ 4 
Drders تار ہنی ک٠ الجداول المناسبة‎ 
Products 

Region 

Shippers 


Sppliers 
Territories 


Prog : Mohamed Youssef 


بعد اضافة الجداول التي نريد استخراج البيانات منها نختار الحقول المناسبة 
للعلم ( نلاحظ انه بمجر ما نضيف الجداول العلاقات تظهر بين الجداول وبالامكان ايضا عمل علاقات بين الجداول ( 


EB Orders E Order Details Wi 
| * اا‎ olun الق *| _ إ5‎ column 
|_| Order 
|_| CustomerID 
Elam, "| LIniEFFÎ 
| wrderDate Quantity 
__ |REquiredDatE Discount 
| |ShippadOate 
|_|ShipYia 


|_ Freight 


في هذا الشكل نلاحظ ظهور الجداول والحقول 


olur E Table wiJEpUE | Sort T¥pE 
F# CompanyMame Customers 
ContactName Customers 
rderDate irders 
LInitPricE [Order Det, 
Quantity [Drder Det... 
Discount [Order Det,,, 
0 


وفي الشكل التالي يبين الكود الخاص بالمشاهد وطريقة ربطه 


SELEZT Aba: Zustomers,. ZompanyMHarme, dbo, Lustorners,. LontactName, dbo, Orders, OrderDatëe, dbo, [Order Details]. 
dba, [Order Details], Discount 

FEM dbo, Orders IMMER. I2I 
dba, [Order Details] OM dbo, Grders, DrderID = dbo, [Order Details]. DrderID INNER 32IN 
dba, Lustomers OM dbo, Drders, ZustomerID = dba, Lustormers, ZustomerID 


بعد الانتهاء من اضافة الجداول والحقول نضغط على زر ۴5 او على 


_olurmn Table wtput Sort Type Sart Order Filter 
LInitPricë Lrder Det,,, 
| Discount [Order Det, ,, 
01 
L1 
% | 


النتحة 


<° 


E 
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i _ampanyamE ContactName crder Date LInikPricE IaNLIEY 

| Wins ek alconls 2, Fal Henrik 7419E 1A:DO:.,, 14,0000 12 1 

| ins êk alcool Z,,. Paul Henrik A416 TAOD:.,, 3,8000 11 1 
ins ek alcoals L,,, Paul Henrigt FIA 12:0U:... 34.8000 2 1 
E spezialitãten Karin Josephs ISIE 12:0U:.., 185,6000 3 1 

| Tams apezialitãten Karin Josephs FISTIAAE TAOU:... 42.4000 4 1 
ane LaFNES Mario Portes BIA TAOD., 7. 7OUU 11 1 

| Hanari Larnes Mario Pontes BT1 TAOU:..,. 42,4000 E J.15 
Hata LaArNMES Mario Pontes IBI 12:0O:... 16,8000 15 .15 
Î victuaillês en stock Mary Saveley FBI 12OU:.,. 16,8000 6 13.05 


ص س س 


ml am سس ر‎ 


1 mw چ‎ 1 


ثانيا : خيارات الجداول 
يمكننا اضافة الخيارات من الحقول مباشرة او من خلال الشفرة كما فعلنا في الدروس السابقةر 
خاصي Sort Type‏ 


( Count - where ... 
Sart TypE 


Ascending 


Descending 
LInsorted 


في حال نرید اظهار بيان معين من حقل معين فنختار خاصية )!ا۴ 


E. E HM 


| ) _olurmn Table wutput Sort Type Sart Order Filter 
LInitPricë Lrder Det,,, 
ulantiky [Order Det,., 
Discourik [Order Det... 
0 
L1 
کا‎ 1 : 3 
| Company a E E E ER E RR | Discount 
F Tams Spezialikaten Karin Josephs 7o13 12:00:1... 42,4000 4 1 
| Suprêmes dêlices. Pascale Lartrain 7A1 12D: ,,, 64.3000 ا4‎ 3,05 
Suprêmes dêlicêeê5 Pascale Lartrfain A1346 12:OO:.., 27,2000 4 ۸ 
Hanar LaArnEs Mario Pontes 7II 12:0... IB. O00D 4 1 
| Rattlesnake Lanı,,. Paula Wilson STA 1346 12:00: ..,. 10,0000 4 ل1‎ 
| QUILE-StAp Horst Kloss SFAUFIAE IAD... 147000 l2 
ULE-Stop Horst Kloss SAIF 12D... 33,4000 1 
[Rirarda ûdrrir= arekê | im êira Raa 12n i2 ann ik 


2 n 
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شرح التعامل مع A۸D0O.Ne‏ 


A0.N۴٣ ..‏ هى التقنية التي تسمح لنا بالتعامل مع فواعد البيانات من داخل بيثة ال . ۸۴۲ حيث تقوم هذه 
التقنيه على مبدا ال أcمز0b oriented programming‏ , وهي عبارة عن مجموعه من ال كءءءهاع و التي 
تمكننا من الوصول إلى البيانات من خلال اللغات التي تدعهما N۴۲‏ . ضمن فضانى الأسماء 22 ل.١۸٠ءاكئلرء‏ و 
system.xml .‏ 


حیٺ تمتاز ال ۸0.٤1‏ بميزة التعامل مع مصدر البيانات في وضعين: الأول وضع متصل ء٤٣٣0ء‏ و 
الوضع الاخر و ضع منفغفصل ٤4‏ ٤٣٣٥ءscءاD٥‏ . 


و لقد نشأت ال آ٤۸00.N‏ من تقنية سابقة تدعى ۸00 و هى اختصار للكلمات ء٥زط0 daa‏ ×ەActiv‏ و كانت 
اد۸00 تمتل مجموعة من ال كمعدعها٤‏ المستخدمة فى لغات البرمجة السابقة مثل اجuءاا‏ 6 ءأئوط للوصول 
إلى البيانات فى قواعد البيانات » و ۸0.۸۴٤1‏ تقوم بنفس الأغراض التي كانت تقوم بها ال ۸500 و لكن 
بأسلوب محدت و أسهل . 


:Data Providers ٽlilaıll‎ تlدوjم‎ 


تسمح لك ۸00.۴۲ بالاتصال مع مصادر البيانات ( برامج إدارة فواعد البيانات على اختلاوها: أوراكل» اSQ‏ 
.Access NS Server‏ وعيرها) ولتحقيق هذا التعميم يوحد مجموعة واحدة من الsع‌sءa|اC‏ في 'ADO.NET‏ 
وبما أن مصادر البيانات المختلفة تعمل ببروتوكولات مختلفة. لذلك فنحن نحتاج إلى طريقة صحيحة للتعامل 
مع کل مصدر بالبروتوکول الذي يناسىه. بعض مصادر البيانات القديمهة تستخدم امc‌ها٥۲ام 008€٥€‏ وبعض 

الحدیت منھا يستخدم 0bءا٥‏ امrot0ocمp.‏ 

0.N۴1‏ ۸0 تقدم طريقة عامة نسبية للتعامل مع مصادر البيانات كل على حده في مكتىة خاصة. هذه 
المکتبات تسمی ۲sءلiاه‏ ا۲ ھا0 وغالىاً یکون اسمها في ۸00.٤۲‏ على اسماء البروتوکولات التي 
تستعملها مصادر البيانات. الجدول التالى يوضح بعض مزودات البيانات المعرفة في ۸00.N٤۲‏ وسابقة A۲!‏ 
التي ستعملها ونوع مصدر البيانات الذي تتعامل معه: 


Table 1. ADO.NET Data Providers are class libraries that allow a common 
way to interact with specific data sources or protocols. The library APIs 
have prefixes that indicate which provider they support. 


Provider API e 
Name Prefix Data Source Description 


CProvider | Ob FOTOS Wh AF r page, TO 
Provider data bases. 
Provider Access or Excel. 


Oracle Data 
Fle at oracle For Oracle Data Bases. 
SQL Data 1 ٍ 
ou | Sql For interacting with Microsoft SQL Server. 
Borland Data Bd Generic access to many data bases such as 
Provider P Interbase, SQL Server, IBM DB2, and Oracle. 


کمنتال يوضح استخدام سابقه :۸۴١‏ عند الاتصال بقواعد البيانات أحد أول الكاننات ءأءمزا0 التي 
ستستخدمها هو اءە‌زطه ionاءمصصدC‏ -کما سيأتي شرحه لاحقاً- والذي سيسمح لك ببدء اتصال مع أحد 
مصادر البيانات. لو كنا سنستخدم ۲ءملiاها۴‏ مام 0٥ا0‏ لكي نتصل مع مصدر البيانات (فاعدة بيانات 
آكسس أو ملف أكسل منلاً) فاننا ببساطة سنضيف سابقة ۸۲١‏ الخاصة بe۲ل0vi Data Pr‏ eDbا0‏ وھى من 
الحدول الĞسابق‏ 0٥ا0‏ الى اسÈۉوم‏ الكانن 4—iJڏzı .OleDbConnecition‏ 
وهكداء كانن الاتصال يبدأ با0 لیصبح i0۸اOdbcConnec‏ عند استخدام مزود ڊlıناٽ «source Odbc data‏ 
وكائن الاتصال يبدأ باو؟S‏ لیصبح ۸٥1ا S|"‏ عند استخدام مزود بیانات .data base SQL Server‏ 


وحيث أننا سنستخدم قاعدة بيانات آكسس في دروسنا و مزود البيانات لهذا النوع هو ط0١ءا0‏ فإن سابقة 


کل کائن سننشنه ستكون ط2ء|ا0 وبامكانك تغییرها إذا کنت تتعامل مع مزود بیانات لقاعدة بیانات أخری كما 
يوضح الجدول السابق! 


۷ 
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ADO.NET Objects : 


1- Connection 

2- Command. 

)وضع متصJ( DataReader.‏ -3 
(وضع منفصل) DataAdapier.‏ -4 
.وضع منغصل ) .0286 -5 


والرسم التالي يوضح مغهوم استخدام كل کانن ونطاقه: 


Client 


Select Command 

Insert Command 

Delete Command SERTER 
omîma nî ا‎ | 


م 


{1- DataSet 


0 
3 
0 
۳ 
۹ 
F1: 
8۴ 
1 
۳ 


TS FHPFpBTE FOO 


£S-DataReader "connect™ 


و إليك خطوات ربط برنامحج بال #٤٥‏ مع فاعدة بيانات تم إنشاؤها على Microsoft Access :—J|‏ 


فى البداية أود ذكر أن قاعدة البيانات التى قمت بانشاءها بسيطة حدا قمت بتسميتها _ء_K‏ و تحتوي على 
حدول واحد فقط یسمی.۔ ۸٥iاaم‏ 


: view >> server explorer الان من القتائمة‎ 
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wiy | Project Build Debug Data 
=| ode FF 
EE} Designer Shift+FF 
E pen 

wipen With... 
ا‎ salutian Explorer w_krl+Alt+L 
4 Class View ctrl+shift+C 


| Serwer Explorer Ltrl+Alt+5 


wktrl+Shift+E 


سيظهر لك ما يلي بجانب صندوق الأدوات: 


ResoUrCE jey‏ ا 


er Explorer 


J10 AAA f 


| 


Specify the folowing ta connect ta Access dala: 


Provider Lonnectior | Advanced | اک‎ 


1. Select or enter a databaze narne: 


A. Enter Information to log or to thëê databašE: 


lLIzer name: Adır 


قاعدة البيانات النه تريذ 
> زبظها بالبرناصج.. 
تم 0K‏ .... 


Test Connection 


x Ê Data Link Properties 


Bd Data Link Properties 


Provider | Connection | Advanced | اک‎ 


Select the dala you want to connect to: 


MedıiaLatalogDE ULE DB Proyider 
MediaL-atalogMergedUBE DOLE DE ProYider 
MediaLlatalogwesbDBE ULE DE Prayider 
Microsoft Jet 3.51 ULE DB Provider 


Microsoft Jet 4.01 OLE OB Provider و‎ 
Microsoft ULE DB Provider For Data Mining Services 
Microsoft ULE DE Provider for Indexing 5 erYIcE 
Microsoft ULE DE Provider for Internet Publlshirig 
Microsoft ULE DB Provider for UDELL Drivers 

Microsoft ULE DB Provider for ULA4PF Services $. 
Microsoft ULE DE Pra¥ider for Uracle 

Microsoft ULE DE Provider for Dutlook Search 

Microsoft DLE DE Provider for SAL Server 

Microsoft ULE DE Simple Pra¥Ider 

MS DataShape 

ULE DE FroYider for Microzalt Directory Serylces 

YSEE Yersloning Enlistment Manager Prony Data Source 


Uk | Caneel | Heb 
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ما يلى:‎ Server e×ماore۲ سيظهر لك في نافذة ال‎ 


E) Seryer Explorer E) Server Explorer 
چ وي اغا ب 8 ك و ةا ۽‎ 
= = 
ا ا ج‎ Data Zonnertians ٤ = ا‎ Data Lonnecktions 
E I aCE55.D:1data base\k-s-b. mdb, Aarin | =1 Fp ACCESS, Dr idata basées-b,mdbtdmin 
+ Ei SEFYEFS Tables 
+ طا‎ WES 


+ ا‎ Stored Procedures 
+ Ei SEFYEFS 


2 
2 


لاحظ بالأعلى أنه تم إدراح قاعدة البيانات التي سنقوم بربطها مع البرنامح , فقط قم الآن بسحب الجدول 
المراد من هنا و إسقاطه على ال) ٥۲۳‏ في هذه الحالة اسم الجدول ,("۲٠ءآاة۴"‏ وبعد ذلك سيظهر لك 
الكائنين التاليين أسغفل ال. ٥۲٣‏ 


aleDbLoannectioni1 EL aleDbÛDataAdapter 1‏ ا 
و لإنشاء |lلكilننj: DataSet‏ 
Hk aleLbDataAdapter 1‏ 
اضغخط شنا بالزر الأيصن 
نح قح باحبیار 
و و Yiew Lode‏ |= 
aleDbZoannectionl HL oleDbDataûAdapker 1 HH data5et11‏ 4 - 
w~onfigure Data Adapter...‏ 


meneralte Datasel,,, 


PFreviewy Daba,,, 


انتهينا الان من ربط ال ٥۲۳‏ مع قاعدة البيانات. 


نريد الآن أن نستعرض محتويات أحد حداول قاعدة البيانات التى قمنا بربطها مع البرنامج: 


ولعمل ذلك سوف نستخدم الأداة ل١أ6ة1ة0‏ لعرض الجدول بها , لذلك قم بسحب هذه الأداة الآان من 
صندوق الادوات و اسقاطھا علی ال ۴٥۲٣۳,‏ 


GÎ Dataarid 


\ 0۰ 
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E 


و وي حالتنا هذه نريد أن يتم تحميل الجدول على ال لأا6ةاة0 بمجرد تشغيل البرنامج لذلك سوف نقوم 
بكتابة الاوامر دlخJ Consitrucitor......J|‏ 


الآن انتقل إلى نافذة ال مله و اكتب الأوامر التالية: 


public Form1 () 


InitializeComponent(); 


try 


{ 
// fill DataSet with data from OleDbDataAdapter 


this.oleDbDataAdapter1.Fill(this.dataSet11, "Patient""); 

// bind DataGrid to DataSet 
this.dataGrid1.SetDataBinding(this.dataSet11, "Patient""); 

} 


catch(Exception ex) 


{ 


MessageBox.Show(ex.Message, "error..!"); 
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شرح البرنامج: 


فى البداية فمنا بتعبنة ال 1ءS؟ةاة0‏ بالجدول "1١ءاiاج٥۶"الموحود‏ في فاعدة البيانات التي فمنا بربطها مع 
البرنامج . و ذلك باستخدام الدالة ١ا۴‏ مع الكلاس ءام (a1a Ada‏ 0bءاه‏ بحيث أنها سوف تستقبل فى البارمتر 


الاول اسم ال أ5S6هاه0‏ المراد تعبنتهاء و البارمتر الثاني هو اسم الجدول. 


و لكي نعرض الجدول في الأداة كأ6ه1ة0 قمنا في السطر الذي يليه بربط الأداة D446‏ بال DataSet‏ 
وذلك باستخدام الدالة وinكہ8iةاة1D0هS))‏ : بحيث أن هذه الدالة تستقبل بارمترين الأول و هو اسم ال 


ا6و الثاني هو اسم الجدول اتفه ود بها. 
أما إذا كان لديك استفسار في عبارة ءاه , إ١‏ فعليك مراحعة الدرس " السيطرة على الأخطاء Exception‏ 
handling "'‏ 


و نتيجة تنغيذ البرنامج كالتالي: 


SES 


| FirstName | Lastlame | PatientlD 
Isarma Emad 1 
Moharrrned Maraoor 


2 
Khalid Ahmed 3 
Haser Ammar 4 


لقد تمكنت الآن من ربط برنامجك بقاعدة البيانات و عرض محتويات الجدول لديك بنجاح» ستتعلم إن شاء الله 
في الدروس القادمة القيام بعمليات متقدمة أكثر على الجداول.. 


\o۲ 
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Reports التقارير‎ 


طريقة إضافة تقرير للمشروع .. 
بسم الله الرحمن الرحيم 
من القسم ۲٥هام×ع‏ ااه أنقر على اسم المشروع بالزر الأيمن ثم تابه الصور التالية : 


‘SDE EX pIOFEF I 


Bê 3 E E E & 


earn ADO.NET DataRelz 


4 أنغر عليه بالزر ايبن 


La] Forma,¥b 
rptZrystalRepaort 1 ,rpt 


Rebuild ر‎ 
lean 


Publish... 


1II YEB HEFEFENEE,,. 
e Wie lass Diagram 


Debug ۴ 


ا ا 


Rename 


i Properties 


Perwy Folder 


indos Forrn,.., 


LISE Lontrol,,, 


w_oarmponent... 


Module,,., 


Lla55,., 
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Templates: سا‎ 


_ Yisual Studio installed templates 


= سے ےا L113‏ 
اا ب ہے > 0 
چ az‏ = ا کا 


Windows Farr Dialog Explorer Form MDI Parent About Box Lagin Farr Splash Screen 55ا‎ 


Î _ BH HE 


Form 
فة كه فة ك‎ 1 
Module Interface Lamponent ZOM Class DataSet SL Database 
55ا‎ 
d4 8 A FH & 
ser Lontrol Inherited Form Inherited lser  Lustom Web Lustom Resources File Settings Fle Lode File 
Lontral antral wontrol ¥ | 


û Crystal Report file that publishes data to a Windows or Web Form 


MaMmE: 


Lreakte a New Lrystal Report Docurnênk 


1 0 Llsin izar 
1 ™ ۱ q the Report iT 


O As a Blank Report‏ اس 


(Fram an Existing Report‏ ا 


~hoaose ãn Expert 


Standard 4 
FE cross-Tab 
Mail Label 


wuides the creation of a typical report, 


\o 
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"J Standard He porî Lreation Wizard 


Datla 
~hoaose the data You want to report on. 


Available Data sources! Selected Tables: 
| Hl: 3 InformationBankDataSet 
BE] TheEank 
EE) data 


- 3 Favorites 
E: CAHistary 
EH: create Meawy L_onnEction 


"J Standard RE POTT Lreallon Wizard 


Grouping 
Optional} Sroup the information on the report, 


EE RA SRNü êt‏ ا 
eı data, Ask‏ 
Em data, Answer‏ 
21-E] TheBank‏ 
“E AskMurmber‏ | 
HEE] data‏ 


__ Browse Daka... _ Find Field... 


تجاوز ,هذه الشاشة الاختيارية وانقر على التالي 


1o0 
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"J Standard RE POTT LTealilon Wizalr û 


Record Selection 
Optional’ Select ã subset of information to displa¥. 


Available Fields: Filter Fields: 
a Report Fields 
: “EE TheBank.,ID 


a TheBank, AskEMNuriber 


eı data, Ask 
E data, ûnsmEr 
TheBank 


a) AERRIORRDEE 
H.-EEÎ data 


J Standard HepOri Lreation Wizard 


Report Style 
Select a Formatting style For the report, 


ûwailable SE¥lEs PreYiein 


standard 

Leading Break 
Traiing:Break. 
Tablo 

GDrap Tablë 

Executive, Leading Break 
Executive, Trailing Break 
shading 

RedfBlue Border 

Maroon! Teal Box 


الخال > 


1٥٦ 
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bectonl [Report Header |‏ ¥ 
ا ر ّ. n‏ ر ّ. ر ا ّ. ر ا ر ر ر ا ا ا ر ا ر ر ا ّ. ا ر ر ا ّ. ۳ 0 ا ر E‏ ا ّ. ا ر ر N‏ ا ۳3 0 ر ر ر ر 0 ر ر r‏ ّ. 0 ا ر ا ا ر ر ر ر ر 
IIIIII IIIIII‏ 
heclond [Fage Header |‏ ¥ 


E METTA ORO OO 


1 2 شا اق 1 وا و ا وا ها و ا و ا اة ا اة ا و ا ةا وا وا وا وا اة ا وة اة ا وة د وة ا وا وا و ا وة ا اة ا و ا و د و د ةا و ا وا ف ا ةا اق ا ق ا اة ا اة ا و ا او ا او ا و 


ط 


¥ becan} [Detalls | 


j ASlumber 


کرک کر کرک کرک کر کر و کک کک کاک کک کک کا کک کک کوک کک کور کیک کک رکوک کو کک کوک کک کو کک کو اک کر وکوک کوک رک کو کوک کک کک کک کک 


ا 


. كعنوان للتقرير‎ ]٥×1 اضف في التقرير بالدات في ۸2هاءم5 مربع نص وليكن اسمه‎ 
CrystalReport1.rpt Î InformationBankDataSet.xsd* 1 Formi1.wb [Design]*  Skart Page E 
8 n | = ۴ 1 |1 E e 1002 ا‎ Susser 


AUOFTNTAAT 


% 
TREE 
23,097 
21,12 
Rea Sunday TT 
TREE 
EKEL 
1132 
EKE 
KEE 


| اشر هنا لمعاينة التقرير 


Main Report Preview 


ا ا 


Main Report 


ثم من القسم ۲٥إoام×E‏ ہ٥ناںام6‏ آنقر علی اسم المشروع بالزر الأیمن ثم اختر >> Add‏ ثم >> عاسم" تم اختر >> 
Windows Form‏ تم اعطیه اي اسم ولیکون ۴٥۲۳2‏ . 
بعد ذلك اذهب إلى ۴٥۲۳2‏ واضف إلية دا5 CrystalReportViewer1‏ . 


بعد ذلك اذهب إلى ۴٠۲۳2‏ في وضع كتابة الكود وأكتب ما يلزم من الكود التالي : 


Prog : Mohamed Youssef 


Imports System.Data 
Imports System.Data.OleDb 
Public Class Form2 

Friend strConn2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Application.StartupPath & 
"Information Bank.mdb;User Ild=admin;Password=;" 

Friend strSQL2 As Siring = "SELECT TheBank.id, TheBank.AskNumber, data.ask, data.answer 
FROM TheBank INNER JOIN data ON TheBank.ID = data.IlD ORDER BY TheBank.AskNumber;" 
"SELECT TheBank.id, TheBank.AskNumber, data.ask, data.answer FROM TheBank INNER JOIN data 
ON TheBank.ID = data.ID WHERE (((TheBank.!ID)=18)) ORDER BY TheBank.AskNumber;" "SELECT 
TheBank.id, TheBank.AskNumber, data.ask, data.answer FROM TheBank INNER JOIN data ON 
TheBank.ID = data.ID ORDER BY TheBank.AskNumber;" 

Friend cn2 As New OleDbConnection(strConn2) 

Friend daTheBankAndData2 As New OleDbDataAdapter(strSQL2, cn2) 

Friend MyDS2 As New DataSet 

Private Sub Form2 Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load 

Try 

cn2.Open() 

daTheBankAndData2.FilI(MyDS2, "TheBankAndData"") 

cn2.Close() 

Dim rpt As New rptCrystalReport1 

افقي او عمودي تحديد مسار التقرير و التحكم في وضع التقرير اما" 

rpt.Load(Application.StartupPath & '"\" & "rptCrystalReport1.rpt"') 

rpt.SetDataSource(MyDS2.Tables("'TheBankAndData"")) 

عمودي في وضع التقرير اما افقي او التحكم ' 

rpt.PrintOptions.PaperOrientation = 
CrystalDecisions.Shared.PaperOrientation.DefaultPaperOrientation 

2 هذا الكود يقوم بالكتابه في مربع النص الموجود تاخل التقرير في الموقع رقم ' 

CType(rpit.Section2.ReportObjects('"Text1"), 
CrystalDecisions.CrystalReports.Engine.TextObjec).1 ext = "والأجوبة المخزنه في البرنامج تقرير يستعرض الاسئله"‎ 

معينه من البيانات كي تظهر في التقرير استعمال الفورملا لتحديد مجموعة ' 

للتقرير تعيين شرط تحديد البيانات' 

السجلات يمكنك الإستغناء عن الفورملا إذا اردت ظهور جميع ' 

rpt.RecordSelectionFormula = (' {TheBank.AskNumber} = " & Form1.txtnumber. Text & '""") 

وعرضه تهينةمستعرض التقرير ' 

CrystalReportViewer1.ReportSource = rpt 

CrystalReportViewer1.DisplayGroupTree = False 

CrystalReportViewer1.ShowGroupTreeButton = False 

CrystalReportViewer1.RightToLeft = Windows.Forms.RightToLeft.Yes 

التقرير في حجم الصفحه فتسهل عملية قراءته وهذا السطر الأخير لكي يظهر ' 
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' وملاحظة الفرق يمكنك تغيير القيمة‎ 
شیئا حاول ولن تخسر'‎ 
CrystalReportViewer1.Zoom(1) 
CrystalReportViewer1.Refresh() 
CrystalReportViewer1.Show() 


Catch ex As Exception 
MessageBox.Show(ex.Message, " Show CrystalReport ... '', MessageBoxButtons.OK, _ 


MessageBoxlIcon.Information, MessageBoxDefaultButton.Button1, _ 
MessageBoxOptions.RtlReading) 


End Try 
End Sub 


End Class 
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الجزء السادس : المساعدة مام‎ 


الحصول على المساعده 


يتضمن الفيجوال بيسك ستيديو مركز مراجع الألكترونية يدعى 2005 Microsoft Visual Basic Sudio‏ 
Documentation‏ ( وثائق مایکروسوفت فيیجوال ستديو )٠٠٠٠١‏ يمكنك استعماله لتتعلم أكثر عن بيئة تطوير 
الفيجوال ستيديو › لغة البرمجة فيجوال بيسك » الموارد فى المكتبة kامسمصهإ۴ ٥1‏ › المجتمعات على الخط 
المتخصصة فى الفيجوال بيسك و الفيجوال ستيديو › الادوات المتبقية فى الطقم فيجوال ستيديو . خصص وقتاً 
لاستكشاف موارد المساعدة تلك الأن قبل أن تنتقل إلى الفصل التالى › حيث ستبنى برنامجك الأول. 


مصدران للمساعدة ملفات المساعدة المحلية و المحتوى على الإنترنت 


لقد جرت تحسينات رئيسية علي محتوي معلومات مساعدة فيجوال ستديو و الادوات التي تزود وصولا الي تلك 

المساعدة . في الاساس » هناك موردان اساسيان للمساعدة الالكترونية من فيجوال ستديو : ۰ 

٠‏ يمكنك الوصول الي المساعدة المحلية التي تثبيتها خلال عملية اعداد فيجوال ستديو ٠٠٠٠‏ ( تلك الملفات 
مخزنة علي أقراص تسمي جانا 5D۸N‏ - المكتبة 155۸ - في حزمة البرنامج فيجوال ستديو ) . 

٠‏ يمكنك الوصول الي المساعدة علي الخط ( علي الإنترنت ) من خلال |52١‏ › ومجموعة من مواقع ويب 
المطورين ترعاها مايكروسوفت وتدعيı NET Code Wise Azعgnجnئll . NET Code Wise Community‏ 
Community‏ قیمة بشکل خاص تتضمن مطورین محترفین یستعملون فیجوال ستدیو و فیجوال بيسك ۲۰۰٠٣‏ 
لكتابة برامج من العالم الحقيقي › ويجري تحديث المحتويات والنصائح التي يقدمونها باستمرار ولذا فإنها 
تعكس الميول والهموم والانتصارات الحالية ضمن مجتمع برمجة فيجوال بيسك . 
اضبط تكوين نظام مساعدتك الان ليقدم لك موارد المساعدة المحلية وعلي الإنترنت أثناء تعلمك عن فيجوال 

ببسڭ . 


ضط خیارات نظام المساعدة ٠‏ 


. اختر الأمر ? | 50 سه1 لفتح نظام المساعدة‎ -١ 
Microsoft Documents Explorer „awî H†ML aيلع يقدم فيجوال ستديو مساعدته من خلال أداة مرتكزة‎ 
لفتح‎ Help › Commu ہİاy مستكشف مستندات مايكروسوفت ). يمكنك استعمال عدة أوامر من القوائم‎ ( 
مستكشف المستندات . كل أمر يفتح ويضبط تكوين مستكشف المستندات ليعرض نوعا مختلفا من معلومات‎ 
المساعدة . ?| 50 سه١هو أحد أفضل أماكن البدء › أنه يبين لائحة هرمية بمهام البرمجة الشائعة التي يمكنك‎ 
: استعمالها لايجاد المعلومات التي تحتاج اليها بسرعة . تبدو شاشتك مشابهة للتالي‎ 


iD, ifort iren Fal Faun = HicrarrTî îeual Stud FOOT Car areata n = dicot] Cocnueril Ex glng eT 
اعا فا ناآ تڪ عع‎ 
A KM A BH) + sese Û dsr WR caiats TH Eseries a ak a en FR 
ا‎ i E N | 
LEL: reı-henlip: FES SAD e Creare aT 1 ETCETERA gE OHS“ . Him 
o 
ı ERE ETETE Informa than RizÈ Foairua 

FH ttireg Seria RE Sa Sn E 
Î HTL 2 Hei lı A Seer DO 
BH Traltalireg SA Serr 
BH SA See eem The rfarmalhan yay arg krrireg ba weze aud nat bg frand, Tern Fitri cau hava cmd th grrr 
EH, Sarr Cateaay Erge 
FS Sene Anli SoS Tou hye ehozen ta ime lpeal Help analy for SaSFEh amî F1 Fezüulte, and the tê pêr 
BH SA e egrin Se Tei met ba fore im letal Help. 
E U Berar Û api alr: e ا‎ aE E 
a Si Sei Agha lir Sine 
HH ETA Sangar Fini firgtien Sarr 
FI SA SET Serie Eke 
BE: FiE-Tent teyen 
TT TT 


* kg ueg PET; ey el Sears 
© 


This wTür Cer ba Gaia Fîn zal Halp Faas Teil bawi inci BEI o oF a Kibet af local Hl aE irks 


To correcî las SPF 
1. Irn ha Teals mewı, Hick TipEin ımıa 
: 0 1 ã,. Empavî Help wml her Ed Olin 
BI Trlermashirel Caer | 3: 1n YyYhanı ka šang Hep comîiwnt, ala Try local firat, tham qena 
Tiara pir Briraı Sh kira ã, In 5earzh ifeemge pemuldlers, very ikak HSD Orme or Cal ezome Caan manly i5 selem 
3 See emg eg Ae f 
BH Sphere arpa Cragg 


3I: TOE ar LREHkiE E eri Fees Res 
H-Tree Pry gard; Fre TEkas Lraratinr 
E ST Saryar Err Fri arenı 
ر‎ 
SRL RE AFF Turik 
EH SA Sea Tok Tila 
Hiri evires Ti plrerlgky 
û. Daa Fele Tirrek 
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- انقر موضوعا واحداآً أو أكثر ضمن ن اللائحة ?2 001 سه1 لاستكشاف نوع المواد RE‏ 
> يحتوي نظام المساعدة على منات الأوصاف التقنية والمواد التعليمرة ( يتضمن العديد منها مثال ) .| 
ستضبط تكوين نظام المساعدة بحيث يعرض فقط المحتوي الذي تريده عندما تفتحه . 

۳ علي شريط القوائم مستکشف مستندات مايكروسوفت › انقر 5 ثم انقر !لٺر Options‏ . 
ستري خيارات التخصيص التي يمكنك استعمالها لضبط طريق عمل نظام المساعدة و ( الاإهم من ذلك ) ما هي 
as Ca o SE RES Al‏ 

. انقر الموضوع ١ا تحت الفئة مام اذا لم يكن منتقي من قبل‎ - ٤ 
: تبدو شاشتك متشابهة للتالي‎ 
نصيحتي لك هي أن تضبط خياراتك علي الإنترنت كما هو مبين في هذه الشاشة - انها الاعدادات الافتراضية . أولا‎ 
انتق زر الخيار الوسطي لتحميل محتوي المساعدة من المصادر المحلية في قرصك الصلب أولا ثم من المصادر‎ 
NET Aۍzعganجall‎ ) Code zone Community < MSDN Online sءlقتil علي الإنترنت . تأكد بعدها من‎ 
مهه ) لكي يحمل فيجوال ستديو المقالات الحديثة من مطوري فيجوال بيسك كلما‎ Wise Community 
› علي بعضها الاخر‎ ٥٠۵٠20, استعملت الامر طءإهم5 . اذا وجدت بعد فترة انك تفضل بعض المجتمعات‎ 
. يمكنك تعديل ترتيب البحث أو ازالة البنود من اللائحة‎ 

. انتق خيارات التكوين التي يناسبك › تم انقر ×0 لحفظها‎ -٥ 
يمكنك العودة الي قائمة ام ضمن مستكشف المستندات في اي وقت يكون نظام المساعدة مفتوحا . الان‎ 
لائحة مفضلات المساعدة » تعمل بشكل مشابه‎ . ٠٠٠٠ حاول استعمال ميزة جديدة اخري في فيجوال ستديو‎ 
. كثيرا للائحة المفضلات ضمن انترنت اكسبلورر‎ 


القائمة ما٥‏ فى برنامج 2005 Visual Basic.Net‏ :- 


| Help 1elp | 

@ How Dol Lkrl+F1 
Search wkrl+Alt+F3 
wantents wtrl+Alt+F1 
Index wtrl+Aalt+F2 


ا 
a‏ 
F7 Help Favorites wkrl+Alt+F‏ | 
آفا 
ا 
I =‏ 
| 
ا 
ا 


About Microsoft Yisual SEIdio 


OCYnarnic Help w_trl+Alt+F4 
Index; Results Shift+Alt+F2 
w_ustormer Feedback Options... | 1 
Register Product,,, 
heck For Updates 

١ yê Technical Support 

| | 


صيانة لائحة مفضلات ضمن المساعدة -٠‏ 


-١‏ علي شريط أدوات مستكشف المستندات › انقر زر الاضافة الي مفضلات المساعدة ( الزر الموجود بجانب الزر 
‰5 ۴ ماH1‏ والذي يبين صفحة عليها علامة جمع 
عندما تنقر هذا الزر › يضيف مستكشف المستندات المقال المرئى حاليا الى لائحة مستندات المساعدة المفضلة 
لديك . يمكنك الان ابقاء وماردمساعدتك المفضلة منظمة وبمتناول اليد دائما ! 

. انقر علامة التبويب ۸١١إهه5 في أعلي اطار مستكشف المستندات‎ -١ 
يفتح الاطار ۲>hممS مزودا أداة يمكنك استعمالها لاجراء عمليات بحث نصية محددة ضمن موارد مساعدتك‎ 
. المحلية وعلي الإنترنت‎ 

۳- انقر سهم الخيار موحںومجا ( عامل تصفية للمحتوي ) والغ علامات الاختيار عن كل اللغات ما عدا فيجوال 

بسك . 
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يمكنك ضبط تكوين نظام المساعدة لجعل بحتك يقتصر فقط علي اللغات والتقنيات والمواضيع التي تريدها 

باستعمال أسهم عوامل التصفية . لان بدأت باستعمال فيجوال ستديو للتو › فد تريد بحنك يقتصر فقط علي فيجوال 
بيسك في الوقت الحاضر . 

. Enter bخiض›ls‎ Data Controls اتپ‎ «< Search في مربع النصض‎ - ٤ 
يبحث فيجوال ستديو عن السلسلة النصية ءامءİ٣همء واه في ملفات مساعدتك المحلية وعلي الإنترنت في‎ 
ومجموعات الاخبار والمجتمعات 6٠20ه4٥۴. انتبه انتبه جيدا الي اللائحة رع ام5 في الاطار‎ 10 
التي يمكنك استعمالها لانتقاء كيف تظهر المقالات التي يبحث عليها البحث . تقول الاشاعات أن فریق‎ <« Search 
. بذل جهدا كبيرا لجعل فهم واستعمال نتانج البحث تلك أسهل مما كان عليه في الماضي‎ ۲٠٠٠١ فيجوال ستديو‎ 
. الجديدة التي تنشئ مقتطفا من كل نتيجة بحث معثور عليها‎ ۲٠٠٠١ لاحظ بشكل خاص ميزة فيجوال ستديو‎ 

يعطيك هذا المقتطف فرصة أفضل لتقييم مدي وثاقة صلة كل نتيجة بالبحث . 
-٥‏ انقر زر حفظ البحث علي شريط أدوات مستكشف المستندات 
تلميح بالضافة الي مقالات المساعدة › ينمكنك حفظ البحث المهمة في لائحة مفضلاتك . 
تشبه شاشتك الشكل التالي . لاحظ أن الاطار وە ام۴۷ مام١‏ يتضمن الان المفضلتين الجديدتين اللتين 


( Search - Microsoft Visual Studio 2005 Documentation - Microsoft Document Explorer 


Fila Edit Yjew Tools Window Help 


RR A @Honbol > A search Index AF contents [2] Help Favorites ن ا مداع د اع ارف‎ 


| Help Favûarites ي‎ ٤ ‘Search | Information Not Found | 
ع‎ P, 


mH Help Topics 
Turren1 w| Language: HTML, YESrcripE, Yisual Basic 


ll Help Searches NET Lompact Framework, .NET Development, ASP, NET, Data Mining Extensions (OMA, Mobile & Embedded, 

E O Ts Multidimensional Expressions (MDX), Office Development, Servers & Enterprise, SAL Server ZUDUD, SQL Server 
۰ AUS, SAL Server Analysis Services, SQL Server Data Mining, SQL Server Database Engine, SAL Server 
Integration Services, SQL Server Mobile, SQL Serwer Notification Services, S4L Server Replication, SAL Server 
Reporting Services, Transarct-SAL, Yisual Studio Z2#UUS, Web Development, Winda & ZOM, Windows Forms, 
Windows Wista 


¥! Technology: 


| wl Zontent Type: #4 
Searched For: : | O-O of Û results 


1 ı Currently there are no search results to display. 
Lreakte a help search by entering a kerm in the Search box aboye and û Local Help 
pressing the Search button. 


MASON Online 


Index ResulEs 


Title Location 


A Contents | Index Help Fã... 


Ready 


-١‏ انقر زر تغيير الاسم في الاطار ءم†ااامرجه۴ مام ( يمكنك أيضا نقر باليمين البحث الذي حفظته › ثمى انقر 
Rename‏ (. 

يميز مستكشف المستندات الاسم الذي استعملته لبحثك ويتيح لك تغييره لكي يطابق البحث الفعلي بدقة أكبر . قذه 
الخطوة اختيارية › لكنني أجدها مفيدة . 

. Enter طbخضlg‎ Binding Data to Controls اكٽتب‎ 

يغير مستكشف المستندات اسم البحث ضمن لائحة مفضلاتك . لقد اخترت هذا الاسم لانه بدا أوضح لي من سلسلة 
بحثي الاصلية (لكنك قد تريد تحديد اسم مختلف يطابق بدقةأكبر نتائج البحث التي أرشفتها ). 

. Help Favorites رlط¦bڼٺل! سم۳1 في‎ ٥0 ۱? انقر‎ 

يظهر أإول مقال حفظته في مستكشف المستندات . ستتمرن الان علي حذف مفضلة » وهذه مهارة تصبح مهمة 
عندما تنمو لائحة مقالات مساعدتك المفضلة وتحتاج الي تصغيرها . 

۹- انقر زر الحذف في lلا¦طlر Help Favorites‏ . 


1 
کک 


1 
حح 
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. اذاطلب منك تأكيد نتك بحذف هذه المفضلة › انقر وم۷‎ -١ 
.) يحذف المقال ? | 20 سه1 من لائحة مفضلاتك ( ولكن ليس من نظامالمساعدة‎ 
. انقر زر الاغلاق على شريط على شريط عنوان مستكشف المستندات‎ -١ 
هناك ميزات المساعدة اضافية لتتعلم عنها وتختبرها › لكن الوقت جيد الان لكي ألخص لك أوامر المساعدة‎ 
. ' المهمة ولكي تنتقل الي كتابة أول برنامج لك في الفصل‎ 


Dynamic Help 


9 How Dio 1 ل‎ Search 7 INdEx contents 


No links are available for the current selection. 


تلخيص أوامر المساعدة -٠‏ 


اليك لائحة قصيرة بأوامر المساعدة المفيدة واستعمالاتها ضمن بيئة تطوير فيجوال ستديو 2005 Basic.‏ اVisua‏ :- 


Help | 


لتنظيمها حب هة لبر مجك < i How Do1ı ctrl+F1‏ 
فالبجت .عن كاك مدد A sSearrth Ctrl+Alt+E3‏ 

i Contents Ctrl+Alt+F1 NN حسب الو صوت او‎ 

hy Index trl+Alt+F2 جب الفهرں ین‎ 

lz] Help Favorites trl+Alt+F طالفائمة المفضطلة بلك‎ 

1 ODynarnic Help w_trl+Alt+F4 الميزرة أو الاسر الي اتفه الا‎ - 
FA Index Results ahift+Alt+F2 


Lustormer Feedback Options... 


Register Product... 


I ILL ET E E o E EE 


د heck For Ipdates‏ 
چن الاتصال بمایکر وسوفت 
الحصوا 3 لی ل حم المنتح 


القانمة ماع1 


§ 


Technical Support 


About Microsoft Yisual SEudio 


للحصول علي معلومات مساعدة 
تيمها اختر الم ?۱ ۴٥W ٥0‏ م١٥:٣‏ فی القیجوال ستدیو 
آختر الآمر ما٥‏ ا٥۸۵٥‏ ‡ م١٥:٤‏ قی الفیجوال ستدیو 
آختر الام ا٥اہ‏ ‡ م١٥:٣‏ فی القیجوال ستدیو 
القر الكلمة الأساسية أو الجملة البرمجية الت تهمك ٠‏ تم اضغط ۴1 


انقر زر المساعدة (علامة أستفهام) فى بعض المربعات الحوار ( مثلاً 


أثناء العمل في, مربع الحوا RO a‏ 


. أختر الامر ٣ءإهم؟ ‡ مام١ و أكتب المصطلح الذى تبحث عنه‎ TEE 
د‎ 8 e بالد أيحث عن كلمهة اأساسبهة محددة ك‎ 
Sort BY عن 2 قم بتصفيه و تنظیم البحث باأستعمال اللائحه‎ 
Code gÎ Developer Center رڌil‎ « Community Anilll من‎ TEE 
Zone Community من 55۸ مواع ويب فيجوال ستدیو‎ 


عن الاتصال بمايكروسوفت للحصول على دعم lلمنتج‏ | İختر‏ !ډٺمر Help Technical Support‏ 
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كيف يمكنك الحصول على المعلومات ؟ 


يمكنك الحصول على, المعلومات من المواقع العربية التالية ٠‏ 


CARE 


eg mal ay: pF 1‏ | اس 


rlArabsaate 
شبكة بوابة العرب‎ 


salem û it 


ww Salem4it. com 


GHD rn‏ ر 


WEYE THE A EHSWER 


از ناباك . 
ااا ليا 
ت ؟ الفط الفرط 


ريع الس مالع ألم وة 


مواقع الفيجوال بيسك العملاقة في, الشرح الاجنبية :- 


1- www.msdn.microsoft.com/vbasic/ 
2- www.devx.com/ 
3-  www.microsoft.com/learning/books/ 


4- www.microsoft.com/learning/trainingd/ 
5- www.microsoft.com/communities/ 


كتب البرمجة بالغة الفيجوال بيسك فى الفروع الاتية:- 


البرمجة باللغة فيجوال بيسك ٠٠٠٠١‏ 

برمجة قواعد البيانات مع أم.۸500. 

برمجة الإنترنت مS۲.۸؟A.‏ 

البرمجة بllأغû .Visual Basic for Applications‏ 
كتب عامة عن برمجة الكمبيوتر. 
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لعن زرل 
رر عل لھ (زس رر 


SOL 


Prog : Mohamed Youssef 
التعرف على لغة الأستعلامات اه5‎ 


لغة تستخدم فى 2005 Basi.‏ اVisua‏ عند اأستخدام وہ¡ ۸0NE 2 Progra”‏ للتعامل لربط البرنامج بقواعد 
البيانات. 
الأهداف٠‏ 


بعد إكمال هذا ١‏ ق » ستتمکكن من تنفيذ ما دت 


.SQا| معرفة أهمية لغة الاستعلامات‎ ١ 

۲ الفرق بين أوامر 5۵1 و تصنيفاتها. 

۳ استعمال اوامر الربط › التجميع »> الفرز. 

؛- أستخدام الدوال التجميعية. 

° أستخدام أوامر الانشاء > الحذف › التعديل أقاعدة البيانات والجدول. 

أنشاء الاستعلامات و الفهارس للحصول على البيانات. 

۷- أستخدام أوامر إدخال البيانات › الحذف » التعديل للبيانات. 

۸- أجراء العمليات الحسابية و المنطقية للبيانات. 

۹- أستخدام المعاملات و الفرق بينهما فى الحصول على البيانات المطلوبة . 
-٠‏ معرفة الفرق بين الربط › الدمج بأنواعه. 


مايكروسوفت فيجوال بيسك ٠٠٠٠‏ هو ترقية و تحسين مهمين لنظام تطوير الفيجوال بيسك ٠‏ و ترقية تكرارية لبرنامج 
الفيجوال بيسك ٠٠۳‏ دوت نت و يعطيك الملحق القدرة على معرفة لغة الاستعلامات اSQ.‏ 


و تستخدم عند ربط الفيجوال بيسك بقواعد البیانات و تستخدم وہ¡ A0. 2 r٥a‏ و التعامل مع المکتبات 58ءا0) 
( ۸۲ا ۵C‏ , واستخدام التصنيفات التى تستخدم لربط قواعد البيانات بانواعها مثل:- 


SQL Server 2000 OR 2005 
Oracle 

My SQL 

Ms Access 2000 OR 2003 


هذه هى البرامج التى تستخدم لغة الاستعلامات اه5. 


محتوعع اطلحق الأول 00۸18١۲‏ 


الجزء الأول : "' أوامر معالحة البيانات " ا١0‏ : 


Select جذ‎ 

عبارة الشرط مط 

معامل )اا فى الشرط 

أمر أضافة صف فی الجدول ہاہ! مہا 
أمر التعديل فى الجدول ماولمل 

أمر الحذف من الجدول ممامD‏ 


الجزء الثان : الأوامر المتقدمة و دوال اغ ب— SQL Function‏ : 


عبارة الترتيب 6y‏ مك0 
المعاملين ٠‏ - لكك 

|١ المعامل‎ 

Between ..... and المعامل‎ 

الاسم المستعار وما 

الربط باستخدام رامل 

Union and Union AlI| الدمج باستخدام‎ 
SQL Function JI 


SQL Group By and Having jرفئİاو التجمیع‎ 


الجزء الثالث :" أوامر تعريف البيانات" اا0 : 


1 


أنشاء قاعدة ائبيlنGlٽ Create Database‏ 
أنشاء جدول فى قاعدة البيانات ماطa]‏ ءCrea‏ 
أمر التعديل على الجدول ماطه۲ ۲ا۸ 


Select Into جملة‎ 


Create View مںaaw)‎ sli 


Prog : Mohamed Youssef 


Prog : Mohamed Youssef ۰‏ 
جلشدو الله الوحمن الرحيم 


اولا مقدمه SQL‏ - 


هى لغه قياسيه من لغات الحاسب لدخول ومعالجه قواعد البيانات 


Structured Query Language : SQL ھی‎ lh 
-٠ لغه بناء الأستعلامات الهيكليه‎ 


ANSI هى لغه قياسيه من لغات الحاسب الخاصه بمعهد‎ -١ 
تمكنك من الدخول لقواعد البيانات‎ - 

۳- تمكنك من إستخراج البيانات من القاعده 

“- تمكنك من إضافه بيانات إلى قاعده البيانات 

ه- تمكنك من من حذف بيانات من القاعده 

“- تمكنك من تعديل البيانات المسجله 

۷- أخيرا هى لغه سهله التعلم والفهم 


لغه ا56 هی لغه قیاسیه : 

هى لغه من اللغات الفياسيه الخاصه بمعهد 
ANSI (American National Standards Institute)‏ 
تمكنك من دخول ومعالجه نظم توعد llبlıنlٽت Database System‏ 
جمل 1ا5۵ تعمل مع برامج قواعد البيانات مثل : 


Ms-Access , Ms-SQL Server , DB2 , Oracle ,؛SQL‎ Server 2000 OR 2005 , etc. 
: تنقسم لغه 501 إلى قسمين‎ 
SQL Data Manipulation Language (DML) =1 


هو القسم المسئول عن : معالجه البيانات 


-١‏ اءمامS‏ : إستخراج البيانات من قاعده البيانات 
|NSERT |N70 -1‏ : إضافه بیانات جدیدہ 

۳- ماaلمل‏ : التعديل على البيانات المسجله 

“؛- Delete‏ ` حذف البيانات من القاعده 


2- Data Definition Language (DDL) 
هو القسم المسئول عن : تعريف البيانات‎ 


Create Database -‏ : لأنشاء قاعده بیانات جدیده 
1- eاrab Create‏ : لأنشاء جدول داخل قاعدہ بیانات 
۳- ماطaا Alter‏ : للتعديل فى الجدول 

“- ماطه† مها : لحذف الجدول من قاعده البيانات 
Create index -°‏ : لأنشاء مفتاح للبحث 

Drop iہnلe× -٦‏ : لحذف مفتاح البحث 


Prog : Mohamed Youssef 
SQL Data Manipulation Language (DML) الجزء الاول ""معالجة lأبيlنlت"" ب‎ 


Select 4ذiمڄج‎ 


تستخدم فى إستخراج بيانات من داخل الجدول حسب المطلوب 


تكتب الجمله كالتالى: ×ھا" Sy‏ 


ملاحظه هامه : جمل 5۵1 غير حساسه لحاله الحروف 
لا یوجد فرق SELECT = select‏ 


مثال على الجدول التالى : 


The database table "Persons'": 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Svendson Tove Borgvn 23 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


نريد أختيار الأسم الأول و الأسم اÎJخڍıر (FirstName , LasÎName)‏ 
تكتب الجمله كالتالى : 


SELECT LastName,FirstName FROM Persons 
: ويكون الناتج كالتالى‎ 
Rموuاإt: النتيجه‎ 


LastName FirstName 
Hansen 

Svendson 

Pettersen 


لأختيار جميع البيانات تكتب كالتالى : 
SELECT * FROM Persons‏ 
وتكون النتيجه کكالتالى : 


النتیجه :tاuںsuمR‏ 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Svendson Tove Borgvn 23 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


ملاحظه هامه : بعض نظم إداره قواعد البيانات تتطلب وجود ( :; ) فى نهايه جمله 561 وهذا لان بعض النظم تدعم تنفيذ أكثر من 


۱1۹ 
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SELECT DISTINCT وھى جمذ4‎ S1٤٥7 الأن نندرج لجمله أخرى او إضافه لجمله‎ 


إضافه كلمه 1571١٥١‏ للجمله تمكنك من العرض القيم بدون تكرار (يعنى لو الجدول فيه بیان متكرر اکتر من مره بتعرضه مره 
واحده بس) . 


مثال : على أستخدام 0157۱١٥‏ وعدم أستخدامها 
SELECT Company FROM Orders‏ 


"Orders" table 


Company OrderNumber 
Sega 3412 
W3Schools 2312 
Trio 4678 
W3Schools 6798 
Aesuاt: النتیجه‎ 

Company 

Sega 

W3Schools 

Trio 

W3Schools 


0۱8۲۱١٧7 هنا واضح الفرق عند أستخدام‎ 
SELECT DISTINCT Company FROM Orders 
Rموںuاt: النتیجه‎ 
Company 
Sega 
W3Schools 


Trio 
الان ننتقل لجز ء اخر الا وهو استخدام الشرط‎ 


V۰ 


Prog : Mohamed Youssef 
WHERE `» استخداھم عبار‎ 
: تأتى بعد جمله ٠٠ا5 وتحتوى على الشرط المطلوب ويكون بنائها بهذا الشكل‎ 


Syntax 


SELECT column FROM table 
WHERE column operator value 


مع جمله ١/٠۲١‏ يمكننا أستخدام المعاملات الأتيه : 


المعامل الوصف 

- يساوی 

>> لا يساوی 

> أكبر من 

< أصغر من 

> أکبر من او یساوی 

اصعر من او يساوی 

Between‏ يكون الشرط بين قيمتين 

LIKE‏ للبحث عن كلمات متشابهه 


۲ ملاحظه هامه : فى بعض الأصدارات من 501 المعامل< يكتب هكذا د! 
مثال على استخدام عبارہ ۷۷۸٥۲‏ 


SELECT * FROM Persons 
WHERE City='Sandnes' 


"Persons" table 


LastName FirstName Address City Year 
Hansen Ola Timoteivn 10 Sandnes 1951 
Svendson Tove Borgvn 23 Sandnes 1978 
Svendson Stale Kaivn 18 Sandnes 1980 
Pettersen Kari Storgt 20 Stavanger 1960 
النتیجھ ا ںیم‎ 

LastName FirstName Address City Year 
Hansen Ola Timoteivn 10 Sandnes 1951 
Svendson Tove Borgvn 23 Sandnes 1978 
Svendson Stale Kaivn 18 Sandnes 1980 


7 ملاحظه هامه : على أستخدام علامه التنصيص مع الجمله ( ' )يجب أستخدام علامه تنصيص مفرده مع القيم النصيه مثل 
الأسماء اما بالنسبه للبيانات الرقميه تكتبه من دون علامات . 
متال على ذلك : 


For tex values: للبيانات النصي4‎ 


This is correct: طريقه صحي4‎ 
SELECT * FROM Persons WHERE FirstName="Tove' 
¡is is سإ٥ہو‎ : طریقه خاطنہ‎ 


1۷1 


Prog : Mohamed Youssef 
SELECT * FROM Persons WHERE FirstName=Tove 


For numeric values: 4يمûرلا للبيانات‎ 


This is correct: 4ıص طريقه‎ 

SELECT * FROM Persons WHERE Year>1965 
This is طریقه خاطه :واس‎ 

SELECT * FROM Persons WHERE Year>'1965' 


استخدام المعامل مزا الش طط 


ت تخدم فی تحدید البحث بکلمه معینه مثال البحث عن كل الأسماء الموجود بها حرف او کلمه معینه . 


×2" 5yبنائھا‏ بهذا الشکل 


تستخدم علامه ( ) لتحديد عدد الحروف قبل و بعد الكلمه او الحرف الذى نبحث به مثال : 


فى هذه الحاله سوف تظهر اسماء الأشخاص التی تبدا بحرف ۸ ثم ياتى بعدها اى عدد من الحروف 


SELECT * FROM Persons 
WHERE FirstName LIKE 'a%' 


فى هذه الحاله سوف تظهر اسماء الأشخاص التى تنتهى بحرف ۸ ويكون قبلها اى عدد من الحروف 


SELECT * FROM Persons 
WHERE FirstName LIKE '%a' 


فى هذه الحاله سوف تظهر اسماء الأشخاص التى تحتوى على حرف ۸ فى أى موضوع فى الأسم 
SELECT * FROM Persons‏ 
WHERE FirstName LIKE '%a%'‏ 
بقى لنا الجزء الخاص ب ١٠٠س٥8‏ وسوف نندرج إليه فيما بعد. 
الان ننتقل لجزء جديد الا وهو التعامل مع البيانات 
يوجد لدينا ثلاثه تعاملات مع البيانات 
-١‏ إضاف4 : INSERT INTO‏ 


UPDATE : Jيدعت‎ -1 
DELETE : ھذف‎ -۳ 


إضافه صف للجدول : INSERT INTO‏ 
یکون بنائها کالتالی : 


Syntax 


ويمكنك ايضا تحديد الحقول المطلوب إضافتها فقط وتكون كالتالى : 


1V۲ 


مثال إضافه صف جديد للجدول التالى : 
This "Persons" table:‏ 


City 
Stavanger 


النتيجه تكون كالتالى : 


City 
Stavanger 
Sandnes 


Prog : Mohamed Youssef 
VALUES (value1, value2,....) 


LastName FirstName Address 
Pettersen Kari Storgt 20 


INSERT INTO Persons 
VALUES (Hetland', 'Camilla', 'Hagabakka 24', 'Sandnes') 


LastName FirstName Address 
Pettersen Kari Storgt 20 
Hetland Camilla Hagabakka 24 


لإضافه بیانات فی أعمده (حقول) محدده فقط تکتب کالتالی : 


تكون النتيجه كالتالى : 
City‏ 


Stavanger 
Sandnes 


يكون بناء الجمله كالتالى ٠‏ 


Syntax 


مثال على التعديل على الجدول الحالى . 
Person:‏ 
City‏ 


Stavanger 


لإضافه الأسم الأول فى الصف الثانى : 


INSERT INTO Persons (LastName, Address) 
VALUES ("Rasmussen', 'Storgt 67’) 


LastName FirstName Address 
Pettersen Kari Storgt 20 
Hetland Camilla Hagabakka 24 
Rasmussen Storgt 67 


التعديل فى الأجدوJ‏ : UPDATE‏ 


UPDATE table name 
SET column_name = new value 
WHERE column_ name = some value 


LastName FirstName Address 
Nilsen Fred Kirkegt 56 
Rasmussen Storgt 67 


UPDATE Person SET FirstName = 'Nina' 
WHERE LastName = 'Rasmussen' 


V۳ 


Prog : Mohamed Yousse 
Rموںuاإt: النتیجھ‎ 


LastName FirstName Add ress 
Nilsen Fred Kirkegt 56 Stavanger 


Rasmussen Nina Storgt 67 


لإضافه أسم المدينه وتغير العنوان : 


UPDATE Person 
SET Address = 'Stien 12', City = 'Stavanger’ 
WHERE LastName = 'Rasmussen' 


النتيجه :tإAResu‏ 


LastName FirstName Add ress 


Nilsen Fred Kirkegt 56 Stavanger 


Rasmussen Nina Stien 12 Stavanger 


الحذف من الجدول : 5٤1٤۲٤‏ 
تستخدم فى حذف الصفوف من الجدول وبنائها كالتالى : 


Syntax 


مثال على حذف صف من الجدول : 


Person: 
LastName FirstName Address 
Nilsen Fred Kirkegt 56 Stavanger 


Rasmussen Nina Stien 12 Stavanger 


لحذف الصف 


DELETE FROM Person WHERE LastName = 'Rasmussen'" 


Result النتيحه:‎ 


LastName FirstName Address City 
Nilsen Fred Kirkegt 56 Stavanger 


لحذف جميع البيانات ( الصفوف ) من الجدول 


تستخدم الجمله التاليه : 


1V٤ 


Prog + Mohamed Youssef 


الجزء الثانى الخاص ب ٤٥110١‏ N١ل۴‏ اSQ‏ 


فى هذه المرحله من الشرح سوف نبدأ فى التعامل بمرونه أكثر مع قاعده البيانات عن طريق إضافات لما تم شرحه فى الجزء 


الأول من الدرس عن طريق جمل اه5 


Order By : ®. عبار‎ 


تستخدم لترتيب الناتج من الأستعلام حسب حقل محدد 
متال على التريب : 
Orders:‏ 


سنقوم بتنفيذ جمله الأستعلام التاليه : 


نلاحظ ان البیانات جائنت فی ترتیب حسب حقلرہ هم۳٥٥٤‏ 


إذا اردنا الترتيب بأكثر من حقل تكون كالتالى : 


ماذا لو اردنا عكس الترتيب كيف يتم ذلك 


مثال : 


Company OrderNumber 
Sega 3412 
ABC Shop 5678 
W3Schools 2312 
W3Schools 6798 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company 


النتیجھ :†إاںsمR‏ 


Company OrderNumber 
ABC Shop 5678 
Sega 3412 
W3Schools 6798 
W3Schools 2312 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company, OrderNumber 


النتیجھ :†إاuں‌sمR‏ 


Company OrderNumber 
ABC Shop 5678 
Sega 3412 
W3Schools 2312 
W3Schools 6798 


1V0 


Prog : Mohamed Youssef 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company DESC 


النتيجه :اإاuںومR‏ 

Company OrderNumber 
W3Schools 6798 
W3Schools 2312 

Sega 3412 

ABC Shop 5678 


فى حاله اننا نريد أستخدام الطريقتين كيف يتم ذلك 


مثال : 
يمكن عمل ذلك بطريقتين 
الطريقه الأولى : 


SELECT Company, OrderNumber FROM Orders 
ORDER BY Company DESC, OrderNumber ASC 


اما الطريقه الثانيه هى كتابه الحقول المطلوب ترتيبها تصاعديا اولا ثم الحقول المطلوب ترتيبها تنازليا 
مثال : 
SELECT Company, OrderNumber FROM Orders‏ 
ORDER BY OrderNumber , Company DESC‏ 


وفى اى من الطريقتين تكون النتيجه واحده 


النتیجہ i:‏ اuںیمR‏ 
Company OrderNumber‏ 
W3Schools 232‏ 
W3Schools 6798‏ 
Sega 3412‏ 
ABC Shop 5678‏ 
الأن ننتقل لمعاملات جديده 
المعاملين 08 - And‏ 
يستخدم هذين المعاملين فى ربط شرطين او أكثر:- 
- المعامل ۸١0‏ يقوم بعرض النتائج فى حاله تحقق جميع الشروط 
- المعامل 0۸ يقوم بعرض النتائج فى حاله تحقق اى شرط من الشروط 
مثال : على الجدول التالى 
LastName FirstName Address City‏ 
Hansen Ola Timoteivn 10 Sandnes‏ 
Svendson Tove Borgvn 23 Sandnes‏ 
Svendson Stephen Kaivn 18 Sandnes‏ 


أستخدام المعامل AND‏ : 


۱۷٦ 


City 
Sandnes 


أستخدام المعامل 0۸ : 


City 
Sandnes 
Sandnes 


أستخدام المعاملين معا : 


City 
Sandnes 
Sandnes 


Address 
Borgvn 23 


Address 
Borgvn 23 
Kaivn 18 


Address 
Borgvn 23 
Kaivn 18 


|١ المعامل‎ 
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SELECT * FROM Persons 
WHERE FirstName='Tove' 
AND LastName='Svendson' 


Aمsںuاt: النتیجه‎ 
LastName FirstName 
Svendson Tove 


SELECT * FROM Persons 
WHERE firstname='Tove' 
OR lastname='Svendson' 


النتیجه :tاuںsuمA‏ 

LastName FirstName 
Svendson Tove 
Svendson Stephen 


SELECT * FROM Persons WHERE 


(FirstName='Tove' OR FirstName='Stephen') 


AND LastName='Svendson' 


النتیجہ :tاsuمA‏ 

LastName FirstName 
Svendson Tove 
Svendson Stephen 


له عده أستخدامات منها انه يمكنك تحديد القيمه المراد عرضها إذا كنت متأكد من وجودها فى أحد الحقول 


بناء الجمله ٠:‏ 


مثال : على الجدول التالى 


City 
Sandnes 
Sandnes 
Stavanger 
Sandnes 


Address 
Timoteivn 10 
Neset 18 
Storgt 20 
Borgvn 23 


۷۷ 


SELECT column_name FROM table _ name 
WHERE column_name IN (value1,value2,..) 


LastName FirstName 
Hansen Ola 
Nordmann Anna 
Pettersen Kari 
Svendson Tove 


SELECT * FROM Persons 


WHERE LastName IN ('Hansen',' Pettersen’) 
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النتیجھ :ا ںوه‎ 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Pettersen Kari Storgt 20 Stavanger 


ويمكن أيضا أستخدامه فى ربط أكثر من أستعلام معا 


فى هذا المثال قمنا بعرض جميع القيم من الجدول الأول 
e1_nameا۲ab‏ بشرط ان یکون الحقل 12۳ء۴۲ موجود 
فى الجدول الثانى مهم 2ءاطta‏ 


BETWEEN ... AND Jjماعnلا‎ 


يستخدم لعرض مجموعه بيانات بين قيمتين نصوص أو أرقام أو تاريخ 


بناء الجمله ٠‏ 


مثال : على الجدول التالى 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Nordmann Anna Neset 18 Sandnes 
Pettersen Kari Storgt 20 Stavanger 
Svendson Tove Borgvn 23 Sandnes 


عرض البيانات الموجوده بين القيمتين 


SELECT * FROM Persons WHERE LastName 
BETWEEN 'Hansen' AND 'Pettersen' 


النتیجھ :tاuںsuمR‏ 


LastName FirstName Address City 
Hansen Ola Timoteivn 10 Sandnes 
Nordmann Anna Neset 18 Sandnes 


عرض البيانات الغير موجوده بين القيمتين 


SELECT * FROM Persons WHERE LastName 
NOT BETWEEN 'Hansen' AND 'Pettersen' 


النتیجھ :tاsuمRe‏ 


۷۸ 
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FirstName Address City 
Kari Storgt 20 Stavanger 
Tove Borgvn 23 Sandnes 


تستخدم نفس الطريقه مع الأرقام والتواريخ مع مراعاه 
ان التواریخ لا تکون بین علامتی (') بل يستخدم (#) . 


الأسم المستعار_وهزا۸ 


يستخدم فى تغيير اسم الجدول او الحقل عند عرضه نستخدمه عن طريق كلمه ۸S‏ 


البناء فى حاله الجدول : 


البناء فى حاله الحقل : 
مثال : على الجدول التالى 


This table (Persons): 


FirstName Address City 

Ola Timoteivn 10 Sandnes 
Tove Borgvn 23 Sandnes 
Kari Storgt 20 Stavanger 


LastName 
Pettersen 
Svendson 


LastName 
Hansen 

Svendson 
Pettersen 


SELECT LastName AS Family, FirstName AS Name 


نلاحظ أسماء الحقول (الأعمده) 


Name 
Ola 
Tove 
Kari 


FROM Persons 


النتیجہ :tاuںsمA‏ 


Family 
Hansen 
Svendson 
Pettersen 


SELECT LastName, FirstName 
FROM Persons AS Employees 


Employees:‏ eاrabانلاحظ‏ ان اسم الجدول 


النتیجھ :tاuںsمR‏ 


LastName FirstName 


۷۹ 


Hansen 
Svendson 
Pettersen 


Prog : Mohamed Youssef 


الربط ١١0ل‏ 


موضوع من اهم مواضيع 5۵1 هو الربط بين الجداول الذى يسهل كثير فى عرض البيانات من الجداول التى تحتوى على 
علاقه مثل الموظف و القسم . 


فى بعض الأحيان نحتاج إلى عرض بيانات من جدولين او أكثر لجعل النتيجه كامله يجب انشاء علاقه . 


الربط بین الجداو یتم عن طریق المفتاح الأساسی (ره) ر۲٥‏ ۶۲) الحقل الذی یکون مفتاح اساسی لا يمكن تكرار البيانات 
بداخله . 


فى الجدول التالى حقل (۱0_ءءرهام"ع) هو حقل مفتاح اساسى الخاص بجدول الموظفين . 


اما فى جدول الثانى الحقل (۲_|2هل0۲) هو حقل المفتاح الاساسى للجدول وفيه ايضا مفتاح خارجى وهو حقل 
.(Employee_ID)‏ 


الجدول الأُول:s٥ءyہlاEmp‏ 


Employee_ID Name 

01 Hansen, Ola 

02 Svendson, Tove 

03 Svendson, Stephen 
04 Pettersen, Kari 


الجدول الثاثنى :ول0 


Prod_ID Product Employee_ID 
234 Printer 01 
657 Table 03 
865 Chair 03 


مثال : نريد ان نعرف من طلب منتج وما هو المنتج 


SELECT Employees.Name, Orders.Product 
FROM Employees, Orders 
WHERE Employees.Employee_ID=Orders.Employee_ID 


النتیجه :إا uںومR‏ 

Name Product 
Hansen, Ola Printer 
Svendson, Stephen Table 
Svendson, Stephen Chair 


مثال : نرید ان نعرف من طلب المنتج (۲ع†ہ¡ا٥)‏ 


SELECT Employees.Name 

FROM Employees, Orders 

WHERE Employees. Employee _ID=Orders.Employee_ID 
AND Orders.Producit='Printer' 


۸۰ 


Prog : Mohamed Yousse 
النتیجھ :ا ںوه‎ 


Name 
Hansen, Ola 


SELECT field1, field2, field3 

FROM first table 

INNER JOIN second table 

ON first _table.keyfield = second_table.foreign_keyfield 


مثال على استخدIم NNER JOIN‏ : 
بناء الجمله ٠‏ 


: تنفيذ الجمله على المثال‎ 
SELECT Employees.Name, Orders.Product 
FROM Employees 
INNER JOIN Orders 
ON Employees.Employee_ID=Orders.Employee_ID 


النتیجه :tاsuمR‏ 


Name Product 
Hansen, Ola Printer 
Svendson, Stephen Table 
Svendson, Stephen Chair 


تقوم الجمله ا0ل |١۸‏ بعرض جميع البيانات المشتركه بين الجدولين 
مثال علی استخدام 0۱۸ل E۴۲‏ : 


بناء الجمله ٠‏ 


تنفيذ الجمله على المثال ٠‏ 


SELECT Employees.Name, Orders.Product 

FROM Employees 

LEFT JOIN Orders 

ON Employees. Employee_ID=Orders.Employee_ID 


ەجیتنلاRەsuاt:‎ 
Name Product 
Hansen, Ola Printer 
Svendson, Tove 
Svendson, Stephen Table 
Svendson, Stephen Chair 


Pettersen, Kari 


تقوم الجمله ۸١0۱ل 1٤۴۲‏ بعرض جميع البيانات من الجدول 
الأول eeرہام‏ ع حتی لو لم توجد فی الجدول الثانی 


مثال على أستخدام RIGHT JOI|N‏ : 


بناء الجمله ٠‏ 


۱۸1 


e 


تنفيذ الجمله على المتال : 


SELECT Employees.Name, Orders.Product 

FROM Employees 

RIGHT JOIN Orders 

ON Employees.Employee_ID=Orders.Employee_ ID 


النتیجه :tاںومR‏ 


Name Product 
Hansen, Ola Printer 
Svendson, Stephen Table 
Svendson, Stephen Chair 


تقوم الجمله ١1١0ل ۸|6۲١‏ بعرض جميع البيانات من الجدول الثانى ول0 حتى لوتةجد فى الجدول الأول 
مثال على أستخدام جمذ4 INNER JOIN‏ : 
نريد عرض اسماء الموظفين الذن طلبوا المنتج (Printer)‏ 


SELECT Employees.Name 

FROM Employees 

INNER JOIN Orders 

ON Employees.Employee_ID=Orders.Employee_ ID 
WHERE Orders.Product = 'Printer' 


ەجیتنلاResuاt:‎ 


Name 
Hansen, Ola 
ّ جدول يوضح الفرق بين انواع الربط فى لغة الاستعلامات‎ 


نوع الربط السجلات الناتجة من الجدول الايسر السجلات الناتجة من الجدول الايمن 


السجلات المتعلقة بالجدول الايمن فقط السجلات المتعلقة بالجدول الايسر فقط 
LEFT‏ السجلات المتعلقة بالجدول الايسر فقط 
RIGHT‏ السجلات المتطلقة بالجدول اين ك 


وبهذا نکون انتهینا من شرح جمله ا0ل . 


UNION and UNION ALL gaأl‎ 


تستخدم لدمج حقلين من جدولين مختلفين ولكن يجب 
ان يكون نوع البيانات فى الحقلين واحد اى يكون نصوص او ارقام ..........الخ 


البناء للجمله يكون كالتالى : 


1۸۲ 
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: مثال‎ 
Employees Norway: 


E_ID E Name 

01 Hansen, Ola 

02 Svendson, Tove 

03 Svendson, Stephen 
04 Pettersen, Kari 


Employees USA: 


E_ID E Name 

01 Turner, Sally 

02 Kent, Clark 

03 Svendson, Stephen 
04 Scott, Stephen 


نرید دمج الحقل N۸۷1۳‏ ع فى كل من الجدولين : 


SELECT E_Name FROM Employees_Norway 
UNION 
SELECT E_Name FROM Employees USA 


Rمs‌ںاt: النتیجھ‎ 
E Name 
Hansen, Ola 


Svendson, Tove 
Svendson, Stephen 
Pettersen, Kari 
Turner, Sally 
Kent, Clark 
Scott, Stephen 
. نلاحظ ان النتيجه ظهرت بدون تكرار للبيانات‎ 
: UNION ALL أستخدام‎ 


مثل أستخدام ١۱0١ل‏ الفرق انه يقوم بعرض جميع البيانات حتى لو يوجد تكرار . 


البناء للجمله يكون كالتالى : 


مثال : نرید دمج الحقل ۸1۴٤‏ _ع فى الجدولين السابقين 


SELECT E_Name FROM Employees _ Norway 
UNION ALL 
SELECT E_Name FROM Employees USA 


Result: النتيجه‎ 


۸۴۳ 
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E Name 

Hansen, Ola 
Svendson, Tove 
Svendson, Stephen 
Pettersen, Kari 
Turner, Sally 

Kent, Clark 
Svendson, Stephen 
Scott, Stephen 


نلاحظ ظهور جميع البيانات مع تكرار احد الأسماء المشترك فى الجدولين . 
(الأن ننتقل إلى درس مهم جدا فى لغه 501 الا وهو الدوال) 


SQL Functions JIgدأil‎ 


لغه 561 بها الكثير من الدوال العدديه والحسابيه 


البناء الأساسى لأى داله ٠:‏ 


٠ الدوال‎ 


الداله 
AVG(column)‏ 
COUNT (column)‏ 
COUNT()‏ 
First(column)‏ 
last(column)‏ 
Max(column)‏ 
Min(column)‏ 
SUM(column)‏ 
COUNT (DISTINCT column)‏ 


مجموعه من الأمثله : 


SELECT function(column) FROM table 


الوصف 
لإيجاد الوسط الحسابى للحقل المحدد 

معرفه عدد الصفوف(السجلات) فى الحقل بدون السجلات الفارغه 

معرفه عدد الصفوف فى الجدول 

معرفه قيمه اول سجل فى الحقل 

معرفه قيمه أخر سجل فى الحقل 

معرفه أكبر قيمه سجل فى الحقل 

معرفه أضغر قيمه سحل فى الحقل 
معرفه إجمالى القيم فى الحقل 

SERVER‏ ا5Qعدد‏ السجلات فی الحقل بدون تکكرار تعمل فقط على 


SELECT AVG(Column) From Table 

SELECT COUNT(column) From Table 

SELECT COUNT() From Table 

SELECT First(column) From Table 

SELECT last(column) From Table 

SELECT Max(column) From Table 

SELECT Min(column) From Table 

SELECT SUM(column) From Table 

SELECT COUNT(DISTINCT column) From Table 


1۸٤ 
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SQL GROUP BY and HAVING jرفنl ال‎ 


الدوال العدديه مثل الداله ل5 كثيرا ما تحتاج إلى التجمیg GROUP BY‏ 


بناء الجمله ٠:‏ 


مثال للتوضيح : على الجدول التالى 


Company Amount 
W3Schools 5500 
IBM 4500 
W3Schools 7100 


ننفذ الجمله التاليه: 
SELECT Company, SUM(Amount) FROM Sales‏ 


Returns this result: 4جيتiنl‎ 


Company SUM(Amount) 
W3Schools 17100 
IBM oo 10 
W3Schools 17100 
. نلاحظ ان جميع السجلات اخذت المجموع كله ولم نعرف مجموع كل سجل‎ 
: GROUP Bإ الأن نجرب جمله الأستعلام بعد إضافه‎ 


SELECT Company,SUM(Amount) FROM Sales 
GROUP BY Company 


Returns this result: 4جيتiنl‎ 


Company SUM(Amount) 
W3Schools 12600 
IBM 4500 
نلاحظ انه تم جمع كل سجل وحده وأصبحت النتيجه اوضح‎ 


الداله 1۸۷GB‏ تستخدم لفرز البيانات حسب شرط معين 


بناء الجمله ٠‏ 


1۸0 
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: تطبيق على نفس المثال السابق‎ 


Company Amount 
W3Schools 5500 
IBM 4500 
W3Schools 7100 


ننفذ جمله الأستعلام التاليه : 


SELECT Company,SUM(Amount) FROM Sales 
GROUP BY Company 
HAVING SUM(Amount)> 10000 


Returns this result : 4جيتill‎ 


Company SUM(Amount) 
W3Schools 12600 


نلاحظ انه تم تحقق الشرط وعرض البيانات اكبر من ٠٠٠٠٠١‏ فقط. 


۱۸٦ 
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Data Definition Language (DDL) الجزء التالث "'تعريف llبlنlت"" ڊ‎ 
فى هذا الجزء من الدرس سوف نقوم بشرح‎ 


Data Definition Language (DDL) 
هو القسم المسئول عن : تعريف البيانات‎ 


Create Database -'‏ : لأّنشاء قاعده بیانات جدیده 
- eاrab Create‏ : لأنشاء جدول داخل قاعدہ بیانات 
۸L٣ ER ABLE -ٌ۳‏ : للتعدیل فی الجدول 

؟؛- DR0P r ABLE‏ : لحذف الجدول من قاعدہ البیانات 
CREATE INDEX -ٌ°‏ : لأنشاء مفتاح للبحث (الفھارس) 
DROP |NDEX -“‏ : لحذف مفتاح البحث 


: Create Database ٽlilڊ‎ oدع|ت‎ ءlشنا‎ Jl 


بناء الجمله كالتالى 


طبعا نحدد اسم قاعده البيانات 


قاعده البيانات ديه هتكون خالية. 


لأنشاء جدول داخل قاعده البيانات ماطa] ‘Create‏ 


يكون بناء الجمله كالتالى : 


متال على أنشاء جدول : 


CREATE TABLE Person 
( 

LastName text(30), 
FirstName text(30), 
Address text(150), 

Age (Number) 

) 


الان يمكننا انشاء جداول وتحديد الحقول وانواع وحجم البيانات فيها . 


1۸۷ 
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الفهرس يصمم فى الجدول حتى يجعل عمليه الأستعلام أسرع كما يمكن انشاء اكثر من فهرس نفس الجدول 
المستخدم لا يرى هذه الفهارس انما هى لتسرع عمليه الأستعلام فقط . 


هناك نوعين من الفهارس النوع الأول لا يمكن ان يتكرر به البيانات اما النوةاع الثانى يمكن تكرار البيانات به . 


البناء للفهرس من النوع الفرید (الذی لا یتکرر) ×ملہ! م۹ueاہ U‏ 


البناء للفهرس من النوع العادى ×ملم| eاSimp‏ 


CREATE INDEX PersonlIndex 
ON Person (LastName) 


لانشاء فهرس بترتیب عکسی : 


CREATE INDEX PersonlIndex 
ON Person (LastName DESC) 


لانشاء فهرس فى حقلين فى نفس الجدول : 


CREATE INDEX PersonlIndex 
ON Person (LastName, FirstName) 


الأمر مہا5 


٧۳‏ ترجمتها الحرفيه إلقاء ولكننا هنا نستخدمها كأمر حذف ولكن حذف ايه ( قاعده بیانات - فهرس - جدول) 


اولا: - حذف قاعد بيانات : يكون بناء الجمله كالتالى 


ثانيا :- حذف جدول من قاعده البيانات : يكون بناء الجمله كالتالى : 


ثالثا :- حذف فهرس : ويختلف البناء حسب نوع قاعده البيانات 
مثال : 


Syntax for Microsoft SQLJet (and Microsoft Access): تliluبئl نوع قاعده‎ 


۸۸ 
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Syntax for MS SQL Server: ٽilgبll نوع اعد‎ 


Syntax for IBM DB2 and Oracle: ٽنlبll‎ oدعاق نوع‎ 
Syntax for MySQL: تIنlيبll نوع قاعد‎ 


أخير امر حذف البيانات من داخل الجدول دون حذف الجدول : 


ALTER TABLE ja! 


يستخدم فى التعديل على الجدول من إضافه وحذف أعمده (حقول) . 


لإضافه حقل : يكون بناء الجمله كالتالى 


لحذف حقل : يكون بناء الجمله كالتالى : 


مثال : على الجدول التالى 


Person: 


LastName FirstName Address 
Pettersen Kari Storgt 20 


: لإضافه حقل جديد‎ 
To add a column named "City" in the "Person" table: 
ALTER TABLE Person ADD City varchar(30) 


النتیجه :tاںومR‏ 


LastName FirstName Address City 
Pettersen Kari Storgt 20 


لحذف حقل من الجدول : 


To drop the "Address" column in the "Person" table: 


۱۸۹ 
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ALTER TABLE Person DROP COLUMN Address 


Rمsuاإا{: النتيجه‎ 
LastName FirstName City 
Pettersen Kari 


SELECT INTO 4أذaج‎ 


تستخدم عاده فى حفظ نسخه أحتياطيه من الجدول 


بناء الجمل كالتالى : 
SELECT column_name(s) INTO newtable [IN externaldatabase]‏ 
FROM source‏ 
لعمل نسخه إحتياطيه من الجدول فى نفس القاعده : 


SELECT *INTO Persons _ backup 
FROM Persons 


لنسخ الجدول لقاعده بيانات أخرى : نستخدم |١‏ 


SELECT Persons.* INTO Persons IN 'Backup.mdb' 
FROM Persons 


يمكن أيضا نسخ حقول محدده فقط: 


SELECT LastName,FirstName INTO Persons backup 
FROM Persons 


نفس المثال السابق ولكن مع إدخال شرط : ٠ما۷‏ 


SELECT LastName,Firstname INTO Persons_backup 
FROM Persons 
WHERE City='Sandnes' 


إذا اردنا نسخ الجدول لكن فى وجود علاق مع جدول أخر : 


SELECT Employees.Name,Orders.Product 

INTO Empl_Ord backup 

FROM Employees 

INNER JOIN Orders 

ON Employees.Employee ID=Orders.Employee_ ID 


CREATE VIEW 4ذaج‎ 


تستخدم لانشاء جمله تعرض بيانات تحت شرط معين 
یمکن أستخدام ای من جمل 5۵1 بها مثل عمل علاقه 
او إضافه داله من الدوال . 


1۹ ۰ 
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: يكون بنائها العام كالتالى‎ 


CREATE VIEW view name AS 
SELECT column_name(s) 
FROM table name 

WHERE condition 


۲ ملاحظات هامه - 
-١‏ قاعده البیانات لا تتأثر بما یتم تنفیذه من شروط او دوال 
- قاعده البيانات لا تقوم بحفظ الناتج فى جدول وانما يقوم محرك قاعده البيانات بتنفيذ الجمله كل مره تقوم بتشغيله فيها 


: Nor wid بعض الأمثله المبنيه على قاعده البيانات‎ 
: ۱ مثال‎ 
CREATE VIEW [Current Product List] AS 
SELECT ProductlD,ProductName 


FROM Products 
WHERE Discontinued=No 


كيف يتم تشغيله : عن طريق الجمله الأتيه 
SELECT * FROM [Current Product List]‏ 
مثال ۲ : 
CREATE VIEW [Products Above Average Price] AS‏ 
SELECT ProductName, UnitPrice‏ 


FROM Products 
WHERE UnitPrice>(SELECT AVG(UnitPrice) FROM Products) 


يتم عرضه بالجمله: 
SELECT * FROM [Products Above Average Price]‏ 
مثال ۳ : 
CREATE VIEW [Category Sales For 1997] AS‏ 
SELECT DISTINCT CategoryName,Sum(ProductSales) AS CategorySales‏ 


FROM [Product Sales for 1997] 
GROUP BY CategoryName 


SELECT * FROM [Category Sales For 1997]‏ 
ويمكن أستخدام الشرط اثناء عرض البيانات : 


SELECT * FROM [Category Sales For 1997] 
WHERE CategoryName='Beverages' 


تم بحمد الله 
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مراجح الملحق ال ول (أوامر 501) : 


كنت 00)۸5 8 
e‏ سلسلة تعلم بسهولة › ماءج0 معلومات أساسية و قواعد اللغة » مهندس عزب محمد عزب 
ه ملخص أوامر SQL For Oracle‏ › د/ صالح زرمبه 
ه كيفية عمل قاعدة بيانات مامج0 كاملة › د/ صالح زرمبه 
٠‏ ملخص و۸٥‏ ااءم5 قواعد البيانات (۲) بإستخدام 2000 ۲٠۷م‏ ا54 » أ/ عبد الرحمن سالم 


الكت الالكترونبث 0۴ ° 


موقع الفريق العربى للبرمجة › المرجع الشامل فى جمل 5۵1 › قام بالنقل والترجمة أحمد حامد 
موقع الفريق العربى للبرمجة › بناء التطبيقات قواعد البيانات العملاقة › تأليف خضر يوسف ترزى 
موقع الفريق العربى للبرمجة › مرجع الأوامر ام۷مS‏ اSQ-ء‏ › تأليف أحمد كمال 

موقع كتب الحاسب العربية › تعلم مم5 501 (الجزء الأول) › تأليف محمود محمد عبد الرازق 
الأساسيات فى قواعد البيانات مءدطهه » تأليف مجلاد مشارى السبعى 

دليل تعلم ال 501 للمبتدئين › تأليف NıaaS7 a)‏ 

مقدمة قواعد البيانات بإاستخدام 5۵1 » تأليف مهندس إبراهيم درويش 


موافع الإننرنخ 5ا5 ام ۷ 


1- http ://www.kutub.info/library/list.php?cat=17 

2- http://www.arabteam2000-forum.com/index.php?showtopic=159394 

3- http://www.arabteam2000-forum.com/index.php?showtopic=87202 

4- http://www.vb4arab.com/vb/forumdisplay.php?f=34 

5- http://www.arabmoheet.net/forum/default.asp?codepage=2&forum no=16 

6- http://www.tartoos.com/HomePage/Rtable/ComputerSchool/Proqramminq/proqram6.htm 
7- http://www.swalif.net/softs/swalif59/softs197329/ 

8- http://vb.vip600.com/showthread.php ?i=214611 

9- http ://www.hiarab.net/article5880. html 

10- http ://www.boosla.com/showArticle.php?Sec=DB&id=23 

11- http://forum.mans-fci.net/viewtopic.php?f=33&i=7680&start=0&st=0&sk=t&sd=a 
12- http ://www.prameq.com/vb/showthread.php?i=37742 

13- http ://www.freelearn.110mb.com/sql2000/tutorials. html 
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„ Visual Studio 2005 


Fisual Na Ket 24006 


Prog : Mohamed Youssef 
6 10554 @§Y قا موس مصطلدان‎ 


مصطلحات : لغه الببزبك اطرکې دوت ند 2005 Visual Basic .Net‏ 


Activate 
Add Form 
Add Project 
ADO .NET 


تنشيط الكائن (حدث لبعض الكائنات) 
إضافة نمودج جاهز 
إضافة مشروع جاهز 
مكتبة التعامل مع قواعد البيانات 
محاذاة (خاصية لبعض الكائنات) 
محاذاة إلي الوسط أو التوسيط (خاصية لبعض الكائنات) 
محاذاة الكتابة إلي اليسار (خاصية لبعض الكائنات) 
محاذاة الكتابة إلي اليمين (خاصية لبعض الكائنات) Alignment - Right‏ 
کک 
بي 


0 


Alignment - Center 


Alignment - Left 


¢ 
دالة تستخدم في الحصول على كود أي حرف أو رمز أو كود أول 
حرف في سلسلة حرفية 
تحجيم تلقائي طبقا لمحتوي الكائن (خاصية لبعض الكائنات) 
لون الخلفية (خاصية لبعض الكائنات) 
نمط الخلفية (خاصية لبعض الكائنات) 
التحكم فى صورة الخلفية للنموذج (خاصية للنموذج) 
كود التعليمات الرمزية لجميع آغراض المبتدئين وهو اختصار 
Beginner's All purpose Symbolic Instruction Code‏ 
مفاهيم اساسية Basic Concepts‏ 


منطقي (نوع البيان) Boolean‏ 


نمط حدود الكائن (خاصية لبعض الكائنات) Border Style‏ 
إيقاف تشغيل البرنامج موؤقتا Break‏ 


عدد صحیيح (نوع البيان) Byte‏ 
Change‏ 


لر 
lL‏ 


Asc () 


Back Color 
Back Style 


BackGroundlmage 


BASIC 


CharacterCasing 
Check Box 


معرفة أو تحديد ما إذا كانت الأداة ستتدخل في تعديل الحروف 
صندوق اختبار (أداة من صندوق الأدوات) 


Chr ( ) 


دالة تستخدم في الحصول على الحرف أو الرمز المناظر لكود 


مل 
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رسم دائرة (وسيلة للنمودج › كود برمجي) Circle‏ 
نقر منفرد بالزر الأيسر للفأرة (خاصية لبعض الكائنات) Click‏ 
مسح الكتابة والرسم من داخل الكائن (كود برمجي) 


زر آوامر (أداة من صندوق الأدوات) Command Button‏ 


ُ 


O 
۳ 
0 


Comparison Operator 
Compiler 


Computer Languages 


Const ( Constant ) 


صندوق تحکم > صندوق الأدو ات Control Box‏ 
دالة تستخدم فی الحصول على السلسلة الحرفية المكافئة لعدد 
معين أو لمتغير عددي 

البعد الحخلى للكتابة أو الرسم عن الحافة اليسري للكائن 
البعد الحالي للكتابة أو الرسم عن الحافة اليمني للكائن Current Y‏ 
نوع البيان (حرفي - عددي - Data Type j‏ 


ir RT TT 


إعلان » تعريف المخزن المتغير أو المصفوفة (کود برمجي) Dim (Dimension)‏ 
سمك خط الرسم داخل الكائن (خاصية لبعض الكائنات) Draw Width‏ 


إغلاق أو إنهاء البرنامج 


CSir( ) 


Current X 


Enterprise Edition 


Event 


البرامج المو جهة بالأحداث Event Driven Programs‏ 


1۹0° 
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الاستجابة للأحداث التي تقع عليه Event Driven‏ 
ملف تنفيذي (البرنامج النهائي EXE File‏ 
تعبير (قد يكون نصا أو حسابا أو 


لون تظليل الرسومات أو لون التعبئة (خاصية لبعض الكائنات) 
نمط تظليل الرسومات أو لون التعبئة (خاصية لبعض الكائنات) 
اڪ ا ڪڪ ي ا ي الصحيح الموجود في عدد 
خط الكتابة (خاصيه لبعض الكائنات) 
حلقة تكرارية (كود برمجي) 
لون الأمامية › لون خط الكتابة (خاصية لبعض الكائنات) 
نموذج (الكائن الرئيسي في البيزيك المرئي) 

Form Layout Window 


بعد نافذة النموذج عند حافة الشاشة العليا (خاصية للنموذج) Form1.Top‏ 
التحكم فى الأطار (خاصية للنموذج) FormBorderStyle‏ 
دالة - للحصول على النتيجة قد تكون (حرفية › عددية › 
وعاء تجميع (أداة من صندوق الادوات) GroupBox‏ 
ارتفاع (خاصية لبعض الكائنات) 


اللغة عالية المستوى (لغة يفهمها الإنسان) 

شريط التمرير الأفقي (أداة من صندوق الأدوات) 
أكبر تغيير في شريط التمرير الافقى 

(خاصية لشريط التمرير) 


Fill Color 
Fill Style 


Fix () 


Fore Color 


High Level Language 


HScrollbar -LargeChange 


HScrollbar -SmallChange 


If....Then ..... Else.... 


أداة رسم (أداة من صندوق الأدوات) 
أضافة صورة الى كائن (خاصية للنموذج) 
إدخال نص أو النقر على أي زر من أزرار صندوق الحوار. 


InputBoX ( ) 


۱۹٦ 
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دالة تستخدم للحصول على مكان حرف أو مكان كلمة مطلوب 


Instr ( ) 


البحث عنها داخل سلسلة حر فية معينة. 
عدد صحيح (نوع البيان) 

أستشعار ذكي (هى القائمة التى تظهر عند كتابة الكود) IntelliSense list‏ 
فترة زمنية مستغرقة (تفاوت على فترات » خاصية لميقاتي) Interval‏ 
التحكم فى الوقت التنفيذ (خاصية للميقاتى) 
أداة العنوان (أداة من صندوق الأدوات) Label Control‏ 
دالة تستخدم لتحويل الحروف الإنجليزية الكبيرة إلي الصغيرة ) ( LCase‏ 


Left 
Len () دالة تستخدم في الحصول على طول أي سلسلة حرفية‎ 
Load تحميل النموذج (إجراءات الحدث)‎ 


عدد صحيح طويل (نوع البيان) Lon‏ 


Long Integer 


Interval 


Low Level Language 


Main Window 

MaxButton 
نموذج واجهة المستند المتعددة‎ 

Multiple Document Interface Form 

Menu Bar 


MessageBox.Show 


دالة عرض الرسائل الثابتة بأى طرق 
دالة تستخدم للحصول على جزء من سلسلة حرفية معينة بدءا من 
حرف معين داخل هذه السلسلة. 


Mid ( ) 


زر الفارة للضغط عليه (حدث لب لبعض الكائنات) 


Mouse Down 


Mouse Move 


حركة زر الفارة (حدث لبعض الكائنات) 
ترك زر الفارة عند الضغط عليه (حدث لبعض الكائنات) 
الكتاية داخل صندوی النصوص في عده اسطر (خاصية للنص) 


MsgBox ( ) 
MultiLine 
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Multiple Branching 


Name Space 


New Project 


New Value 


القيمة الجديدة التي يتم إضافتها للخواص 


- البرمجة الكائينية التوجهية - البنائية‎ 
Object Oriented Programming 
Open Project 


Operator 


سم النموذدج على الشاشة 
صورة (خاصيه لبعض الكائنات) 


Professional Edition اأنسخة‎ 


Project Explorer Window 
Project Window 
Properties Window 

Puse Button 

Radio Button 
Randomize 

ReadOnly 


E 


دالة تستخدم في لاستبدال حرف أو كلمة أو جزء من سلسلة حرفية 
د س د و ) ( Replace‏ 
Reserved Functions‏ 

RightToLeft 


دالة تستخدم في توليد عدد حقيقي عشوائي قيمته أكبر من أو 


تساوي الصفر وأقل من الواحد الصحيح. 


Rnd ( ) 


Run Mode 
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Save Form 


Save Project 


عدد الوحدات الرأسية للكائن و هي المستخدمة مع الرسومات 
نمط وحدة القياس في الكائن (خاصية للنموذج) 


Scale Height 
Scale Mode 


عدد الوحدات الأفقية للكائن و هي المستخدمة مع الرسومات Scale Width‏ 


Screen Saver 
Scrollbar —- Max Value أ قمة لش بط ا‎ 
( Maximum Value ) كبر قيمة لشريط التمرير‎ 
Scrollbar —- Min Value 
( Minimum Value ) 


i 


System Development Life Cycle 


أختيار الزر Select a control‏ 
الفاصلة المنقو طة ):( Semi Colon‏ 
اعداد المشروع للنشر Setup Project‏ 
عددي حقيقي (نو ع البيان) 

احادی الدقة 

خطو ط الزرقاء التى تظهر le‏ ضط المجاذاة الكائنات 
الاوامر الجاهزة فى الفيجوال بيسك ٠٠٠٠١‏ 


Single 
Single Precision 


Size Mode 


Snap Lines 


Solution Explorer 


Source Program 


Special Symbols 


SQL 


++ 
« « 


Stander Edition 
الجمل البرمجية‎ 
جل الصو ۳ الموجودة داخل صندوی الرسم‎ £ 


String Expressions 


Structured Programming 


Symbol 
Text Box Control 
TextBOX 


TextBox — Text 


۱۹۹ 


الک ق الول لے ا کے فے الو 


التوقيت - الميقاتي (أداة من صندوق الأدوات) 

أدوات (قائمة في شريط القوائم) 

لتفادى الاخطاء المنطقية والبرمجية فى البرنامج (قنص 
الاخطاء) 

دالة تستخدم لتحويل الحروف الإنجليزية الصغيرة إلي الكبيرة 


ا E‏ 
او متغير حرفي 
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TimeOfDay ( ) 
Timer 

Title Bar 
Toolbar 
Toolbox 
Tools 


True 


ll 


Try ..... Catch ...... 


UCase () 

Unconditional Branching 
User Interface 
V.ScrollBar 


Val () 


Value 

Variable 

View 

Visible 

Visual Basic 
Visual Studio.Net 
Web Portal 
Width 


Working Area 
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REFERENCES gak! 


8B o0) كتج‎ 


-١‏ مقدمة فى البرمجة الهيكلية › د/ جمال عبد العظيم. 

- الفيجوال بيسك دوت نت ۲٠٠٠٠١‏ " تعلم خطوة بخطوة " ٠‏ الطبعة الأولى ۲٠٠٠‏ › تأليف مايكل هالفرسون › ترجمة 
مركز التعريب والبرمجة بدار العربية للعلوم . 

۳- مادة الكمبيوتر الصف الثالث الأعدادى - الصف الاول الثانوى ٠‏ مقدمة البرمجه باستخدام 2005 Visual Basic.Net‏ < 
للعام الدراسی ۲٠٠۹/۲۰۰۸‏ ¢ إعداد أ.د/ أحمد فهمى أمين محروس ٠‏ مراجعة أ.د/ صلاح مين عليوة. 


التب الالکترونیت ۵×۵ ,5۴ ۶ 


موقع فيجوال بيسك للعرب › مجلة موقع الفيجوال بيسك للعرب › العدد الأول لشهر يناير ۲٠٠۸‏ › إعداد فريق عمل 
الموقع. 

منتدی عرب ناو › دورة کاملۂ فی ۸50.61 › بواسطۂ Youssef‏ . 

موقع كتب الحاسب العربية »› طريقة تصميم أله الحاسبة بإستخدام ۷6.١6‏ › تأليف rمر0]‏ اجuءا۷.‏ 

منتدى عرب ناو › أحدث التطبيقات لبرنامج الفيجوال بيسك دوت نت ۲۰۰٥‏ sا‏ م۷٤‏ 0nناهiاممA‏ » بواسطة 
.Kenana‏ 

موقع العاصفة › تحزيم برامج الفيجوال ستيديو ٠٠٠٠١‏ عمل ال مں†م5 » الكاتب الامبراطور .×۸/١‏ 

منتدى الفيجوال بيسك للعرب › فى رحاب )امس مصه۴۲ .۸٥1‏ » إعداد فريق أعضاء المنتدى. 

منتدى المحيط العربى › تعقب وتصحيح الاخطاء فى الدوت نت » إعداد علاء جمعه. 

الموسوعة العربية للكمبيوتر و الإنترنت › قسم الدورات التعليمية › سلسة كتب الدورات التعليمية الالكترونية › 
مدخل إلى ۷8.۸6۲ › تأليف شاكر › تجميع فريق بيوكوم للتكنولوجيا. 

شبكة المطورون العرب › برمجة أطارعمل بإاستخدام ٥.۸6‏ اوم8 اء »إعداد تركى العسيرى. 

منتدى الفريق العربى للبرمجة › التعامل مع الصور و الرسم › إعداد أ/ عبد الرحمن » أ/ فهمى ياسين. 

موقع كتب الحاسب العربية › تعلم لغة »اوج اهںوءا۷ للمبتدئين و المتوسطين › تأليف حسن عثمان قحوم. 
المركز العالى للمهن الشاملة درنة › قسم الحاسوب ٠‏ ملخصات فى 2003 ٥.٥‏ اوھ امںءا۷ »إعداد مظهر رشيد. 
موقع كتب الحاسب العربية › كيفية التعامل مع مكتية )01۳٤08(‏ ۸50 › تأليف سامح سنوسى. 

تعلم الفيجوال بيسك دوت نت ٠ ۲٠٠٠٠١‏ الاصدارة الأولى › تأليف محمد على كنيفو. 

تعلم الفيجوال بيسك دوت نت ٠١ ٥‏ الاصدارة الثانية › تأليف محمد على کنيفو. 

محاضرات مادة 2005 ۷8.۸6 ( نظرى - عملى ) › تأليف أ.م. محمد الحاج. 

إعداد الفيجوال ستيديوه ۲٠١‏ تأليف غدير سهيل محمد. 

مدخل إلى 2005 c.٥‏ siھB‏ امuوء۷‏ › إعداد محمود صقر. 

مقدمة فى الفيجوال بيسك دوت نت 00« الطبعة الاولى ۲۰۰ > ترجمة مهندس محمد على يوسف. 

كيفية تحزيم برامج 2005 ۷8.۸6 ٠‏ الكاتب غير معروف. 

„Ahmed Hattar dalla « VB.Net 2005 أنشاء قاعدة بيانات 5۵1 ببرنامج‎ 

تحزيم البرامج بالفيجوال بيسك ۲٠٠٠‏ » تأليف هiوومy»‏ ^ ۴a‏ . 

الوجيز فى الجديد › أستثمر اللغة بكل طافتها 2005 ".اوج اعںءا۷ » الطبعة الاولى ٠ ۲٠٠٠١‏ تأليف محمد عبد 
الناصر خطيب. 

Programming with VB.Net‏ › إعداد مھهندس محمد جودة حمایل. 

دورة الفيجوال بيسك دوت نت الشاملة "م٠‏ رع مه5" ٠‏ تأليف محمد الشهرى. 

من الصفر إلى الاحتراف ۷6.۸.٥1‏ › إعداد محمد حمدى غانم. 

تعلم إنشاء قاعدة البيانات 2005 ۷۲م ا54 › الكاتب غير معروف. 

مقدمة عامة للغات البرمجة › إعداد ط / عمار الترك. 
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e6 مواقع الإنترنىخ 5ا5‎ 


1- http :/www.arabteam2000-forum.com/index.php?showtopic=74923 
2- http://forum.moe.qov.om/~moeoman/vb/showthread.php?t=106540 
3- hittp://www.damasgqate.com/vb/t92330.htmil 

4- htitp://www.vb4arab.com/vb/showthread.php?p=11832 

5- http://www.vb4arab.com/vb/forumdisplay.php?f=8 

6- http://books.bdr130.net/3831.html 

7- http://www.barqalshamal.com/vb/showthread.php?i=12337 
8- http ://www.kutub.info/library/list.php?cat=19 

9- http://edu.arabsgqate.com/showthread.php?ti=519099 

10- http ://www.qwled.com/vb/forum156/thread42116.html 

11- http ://www.qassimy.com/vb/showthread.php?i=208438 

12- http://university.arabsbook.com/forum44/thread7093-2.himl 
13- http ://alfotowa.com/vb/showthread.php?p=7542 

14- http://www.barqalshamal.com/vb/showthread.php?i=13467 
15- http://www.qulfson.com/vb/f93/121244/ 

16- http ://www.emtiaz.net/vb/showthread.php?i=2643 

17- http://forum.sh2soft.net/13596.htim 

18- http ://www.uae4ever.com/vb1/Emara9/thread106738.himl 
19- http ://www.arabs2day.ws/forums/index.php?showforum=32 
20- http://www.absba.orqg/showthread.php?i=668464 

21- http ://www.ibtesama.com/vb/showthread-t 10204.html 

22- http://www.bramjnet.com/vb3/showthread.php?i=150370 
23- http ://www.star28.com/book/b7.himl 

24- http ://www.saven7.net/vb/showthread.php?i=31200 

25- http://vb.vip600.com/showthread.php?2t=71427 

26- http://www.ask-pc.com/vbx/showthread.php?i=11489 

27- http://www.elaana.com/vb/f11-2 

28- http://www.hayatech.com/c/showthread.php2i=14725 

29- http://forum.moalem.net/showthread.php?p=10768 

30- http ://vb.ihsac.com/t355/ 


Learn with Video:- 


31- http://www.kutub.info/library/list.php?cat=75 

32- http ://www.youtube.com/watch ?v=qm7lmpkPKF4 

33- http ://www.freelearn.110mb.com/visualbasic/level1/tutorials.htiml 
34- http ://www.freelearn.110mb.com/visualbasic/level2/tutorials.htiml 
35- http://www.almassrawy.com/forum/showthread.php?ti=247 

36- http://www.arabswell.com/vb/showthread.php?t=104946&paqe=5 
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